/* ============================================================
   JELLY LABS STUDIO — 2026 REBUILD
   Deep-sea jellyfish aesthetic + KeeperCore brand fusion
   ============================================================ */

/* ---------- CSS Variables ---------- */
:root {
    --bg-deep:      #060a18;
    --bg-mid:       #0c1229;
    --surface:      rgba(255,255,255,0.03);
    --surface-hover:rgba(255,255,255,0.06);
    --border:       rgba(255,255,255,0.06);
    --border-hover: rgba(255,255,255,0.12);

    /* Jellyfish palette — purples & teals */
    --jelly-purple: #a855f7;
    --jelly-teal:   #2dd4bf;
    --jelly-pink:   #ec4899;
    --jelly-blue:   #3b82f6;
    --accent:       var(--jelly-teal);
    --accent-glow:  rgba(45,212,191,0.25);

    /* KeeperCore brand accent */
    --keeper-green: #22c55e;
    --keeper-glow:  rgba(34,197,94,0.2);

    --text-primary: rgba(255,255,255,0.92);
    --text-secondary:rgba(255,255,255,0.55);
    --text-muted:   rgba(255,255,255,0.35);

    --font-heading: 'Space Grotesk', sans-serif;
    --font-body:    'Inter', sans-serif;

    --ease-out:     cubic-bezier(0.16, 1, 0.3, 1);
    --ease-spring:  cubic-bezier(0.34, 1.56, 0.64, 1);
}

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

.container { max-width:1200px; margin:0 auto; padding:0 24px; }

/* ---------- Background Gradient ---------- */
.bg-gradient {
    position:fixed; inset:0; z-index:-2;
    background: radial-gradient(ellipse 80% 60% at 50% 0%, rgba(168,85,247,0.08) 0%, transparent 60%),
                radial-gradient(ellipse 60% 40% at 20% 80%, rgba(45,212,191,0.06) 0%, transparent 50%),
                radial-gradient(ellipse 50% 30% at 80% 60%, rgba(236,72,153,0.05) 0%, transparent 50%),
                var(--bg-deep);
}

/* ---------- Particles Canvas ---------- */
#particles-canvas {
    position:fixed; inset:0; z-index:-1; pointer-events:none;
}

/* ---------- Cursor Glow ---------- */
.cursor-glow {
    position:fixed; width:500px; height:500px; border-radius:50%;
    background: radial-gradient(circle, rgba(168,85,247,0.06) 0%, transparent 70%);
    pointer-events:none; z-index:0;
    transform: translate(-50%,-50%);
    transition: opacity 0.3s;
}
@media (max-width:768px) { .cursor-glow { display:none; } }

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader {
    position:fixed; inset:0; z-index:9999;
    background: var(--bg-deep);
    display:flex; align-items:center; justify-content:center;
    transition: opacity 0.6s var(--ease-out), visibility 0.6s;
}
.preloader.hidden { opacity:0; visibility:hidden; pointer-events:none; }
.preloader-content { text-align:center; }

.preloader-jelly {
    width:60px; margin:0 auto 20px;
    animation: jellyFloat 2s ease-in-out infinite;
}
.preloader-head {
    width:60px; height:45px;
    background: linear-gradient(135deg, var(--jelly-purple), var(--jelly-pink));
    border-radius: 50% 50% 35% 35%;
    box-shadow: 0 0 30px rgba(168,85,247,0.4);
}
.preloader-tentacles {
    display:flex; justify-content:center; gap:3px; margin-top:2px;
}
.preloader-tentacles span {
    width:2px; height:20px;
    background: linear-gradient(to bottom, var(--jelly-purple), transparent);
    border-radius:2px;
    animation: tentacleWave 1.5s ease-in-out infinite;
}
.preloader-tentacles span:nth-child(2) { height:25px; animation-delay:0.1s; }
.preloader-tentacles span:nth-child(3) { height:30px; animation-delay:0.2s; }
.preloader-tentacles span:nth-child(4) { height:25px; animation-delay:0.3s; }
.preloader-tentacles span:nth-child(5) { height:20px; animation-delay:0.4s; }

.preloader-text {
    font-family: var(--font-heading); font-size:1.1rem; font-weight:600;
    color: var(--text-secondary); margin-bottom:16px; letter-spacing:0.05em;
}
.preloader-bar {
    width:200px; height:3px; background: var(--surface); border-radius:3px;
    overflow:hidden; margin:0 auto;
}
.preloader-progress {
    width:0%; height:100%;
    background: linear-gradient(90deg, var(--jelly-purple), var(--jelly-teal));
    border-radius:3px;
    animation: preloaderFill 1.8s var(--ease-out) forwards;
}

@keyframes preloaderFill { to { width:100%; } }
@keyframes jellyFloat { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-8px); } }
@keyframes tentacleWave {
    0%,100% { transform:translateX(0) scaleY(1); }
    50% { transform:translateX(2px) scaleY(0.85); }
}

/* ============================================================
   FLOATING JELLYFISH
   ============================================================ */
.jellyfish-container { position:fixed; inset:0; z-index:-1; pointer-events:none; overflow:hidden; }

.jellyfish {
    position:absolute;
    animation: jellyDrift 20s ease-in-out infinite;
}
.jelly-body {
    border-radius: 50% 50% 35% 35%;
    position:relative;
}
.jelly-glow {
    position:absolute; inset:-50%; border-radius:50%;
    filter:blur(20px); opacity:0.3;
}
.tentacles {
    display:flex; justify-content:center; gap:2px; margin-top:1px;
}
.tentacles span {
    width:1.5px; border-radius:2px;
    animation: tentacleWave 3s ease-in-out infinite;
}

/* Individual jellyfish positions & sizes */
.jelly-1 { top:10%; left:5%; animation-duration:22s; }
.jelly-1 .jelly-body { width:50px; height:38px; background:linear-gradient(135deg, rgba(168,85,247,0.15), rgba(236,72,153,0.1)); }
.jelly-1 .jelly-glow { background:rgba(168,85,247,0.15); }
.jelly-1 .tentacles span { height:18px; background:linear-gradient(to bottom, rgba(168,85,247,0.2), transparent); }

.jelly-2 { top:30%; right:8%; animation-duration:25s; animation-delay:-5s; }
.jelly-2 .jelly-body { width:40px; height:30px; background:linear-gradient(135deg, rgba(45,212,191,0.12), rgba(59,130,246,0.08)); }
.jelly-2 .jelly-glow { background:rgba(45,212,191,0.12); }
.jelly-2 .tentacles span { height:15px; background:linear-gradient(to bottom, rgba(45,212,191,0.15), transparent); }

.jelly-3 { top:60%; left:12%; animation-duration:28s; animation-delay:-10s; }
.jelly-3 .jelly-body { width:35px; height:26px; background:linear-gradient(135deg, rgba(236,72,153,0.1), rgba(168,85,247,0.08)); }
.jelly-3 .jelly-glow { background:rgba(236,72,153,0.1); }
.jelly-3 .tentacles span { height:12px; background:linear-gradient(to bottom, rgba(236,72,153,0.15), transparent); }

.jelly-4 { top:75%; right:15%; animation-duration:24s; animation-delay:-8s; }
.jelly-4 .jelly-body { width:45px; height:34px; background:linear-gradient(135deg, rgba(59,130,246,0.1), rgba(45,212,191,0.08)); }
.jelly-4 .jelly-glow { background:rgba(59,130,246,0.1); }
.jelly-4 .tentacles span { height:16px; background:linear-gradient(to bottom, rgba(59,130,246,0.15), transparent); }

.jelly-5 { top:15%; right:30%; animation-duration:30s; animation-delay:-15s; }
.jelly-5 .jelly-body { width:25px; height:19px; background:linear-gradient(135deg, rgba(168,85,247,0.08), rgba(45,212,191,0.06)); }
.jelly-5 .jelly-glow { background:rgba(168,85,247,0.08); }
.jelly-5 .tentacles span { height:10px; background:linear-gradient(to bottom, rgba(168,85,247,0.1), transparent); }

.jelly-6 { top:50%; left:40%; animation-duration:26s; animation-delay:-12s; }
.jelly-6 .jelly-body { width:30px; height:22px; background:linear-gradient(135deg, rgba(45,212,191,0.08), rgba(236,72,153,0.06)); }
.jelly-6 .jelly-glow { background:rgba(45,212,191,0.08); }
.jelly-6 .tentacles span { height:12px; background:linear-gradient(to bottom, rgba(45,212,191,0.1), transparent); }

@keyframes jellyDrift {
    0%   { transform: translate(0, 0) rotate(0deg); }
    25%  { transform: translate(30px, -20px) rotate(3deg); }
    50%  { transform: translate(-10px, -40px) rotate(-2deg); }
    75%  { transform: translate(20px, -15px) rotate(4deg); }
    100% { transform: translate(0, 0) rotate(0deg); }
}

@media (max-width:768px) {
    .jellyfish { opacity:0.5; }
}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.header {
    position:fixed; top:0; left:0; right:0; z-index:100;
    padding:16px 0;
    background: rgba(6,10,24,0.6);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--border);
    transition: background 0.3s, padding 0.3s;
}
.header.scrolled {
    padding:10px 0;
    background: rgba(6,10,24,0.85);
}

.nav { display:flex; align-items:center; justify-content:space-between; }

.logo { display:flex; align-items:center; gap:10px; font-family:var(--font-heading); font-weight:700; font-size:1.15rem; }
.logo-icon { font-size:1.4rem; }

.nav-menu { display:flex; align-items:center; gap:8px; }
.nav-link {
    padding:8px 16px; border-radius:8px; font-size:0.9rem; font-weight:500;
    color: var(--text-secondary); transition: color 0.25s, background 0.25s;
}
.nav-link:hover { color: var(--text-primary); background: var(--surface-hover); }
.nav-cta {
    background: linear-gradient(135deg, var(--jelly-purple), var(--jelly-teal));
    color:white !important; font-weight:600;
}
.nav-cta:hover { opacity:0.9; background: linear-gradient(135deg, var(--jelly-purple), var(--jelly-teal)); }

.nav-toggle { display:none; background:none; border:none; cursor:pointer; padding:8px; }
.hamburger {
    display:block; width:24px; height:2px;
    background: var(--text-primary); border-radius:2px;
    position:relative; transition:0.3s;
}
.hamburger::before, .hamburger::after {
    content:''; position:absolute; left:0; width:100%; height:2px;
    background: var(--text-primary); border-radius:2px; transition:0.3s;
}
.hamburger::before { top:-7px; }
.hamburger::after { top:7px; }

@media (max-width:768px) {
    .nav-toggle { display:block; }
    .nav-menu {
        position:fixed; top:0; right:-100%; width:280px; height:100vh;
        flex-direction:column; align-items:stretch; justify-content:center;
        background: var(--bg-mid); padding:40px;
        transition: right 0.4s var(--ease-out); gap:4px;
        border-left: 1px solid var(--border);
    }
    .nav-menu.active { right:0; }
    .nav-link { padding:14px 20px; font-size:1.05rem; }
    .nav-toggle.active .hamburger { background:transparent; }
    .nav-toggle.active .hamburger::before { top:0; transform:rotate(45deg); }
    .nav-toggle.active .hamburger::after { top:0; transform:rotate(-45deg); }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display:inline-flex; align-items:center; gap:8px;
    padding:12px 28px; border-radius:12px; font-size:0.95rem; font-weight:600;
    font-family: var(--font-heading);
    transition: transform 0.25s var(--ease-spring), box-shadow 0.25s;
    cursor:pointer; border:none;
}
.btn:hover { transform:translateY(-2px); }
.btn-primary {
    background: linear-gradient(135deg, var(--jelly-purple), var(--jelly-teal));
    color:white;
    box-shadow: 0 4px 20px rgba(168,85,247,0.3);
}
.btn-primary:hover { box-shadow: 0 8px 30px rgba(168,85,247,0.4); }
.btn-glass {
    background: var(--surface);
    color: var(--text-primary);
    border: 1px solid var(--border);
    backdrop-filter: blur(10px);
}
.btn-glass:hover { border-color: var(--border-hover); background: var(--surface-hover); }
.btn-glow { box-shadow: 0 4px 25px rgba(168,85,247,0.35), 0 0 60px rgba(45,212,191,0.1); }
.btn-glow:hover { box-shadow: 0 8px 35px rgba(168,85,247,0.45), 0 0 80px rgba(45,212,191,0.15); }
.btn-full { width:100%; justify-content:center; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
    min-height:100vh; display:flex; align-items:center; justify-content:center;
    position:relative; padding:120px 0 80px; text-align:center;
}
.hero-content { max-width:700px; position:relative; z-index:1; }

.hero-badge {
    display:inline-flex; align-items:center; gap:8px;
    padding:6px 16px; border-radius:100px;
    background: var(--surface); border:1px solid var(--border);
    font-size:0.8rem; font-weight:500; color:var(--text-secondary);
    margin-bottom:24px;
}
.badge-pulse {
    width:8px; height:8px; border-radius:50%;
    background: var(--keeper-green);
    box-shadow: 0 0 8px var(--keeper-green);
    animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

.hero-title {
    font-family: var(--font-heading); font-size: clamp(2.8rem, 7vw, 5rem);
    font-weight:700; line-height:1.1; margin-bottom:16px;
}
.title-line { display:block; }
.title-gradient {
    background: linear-gradient(135deg, var(--jelly-purple), var(--jelly-teal), var(--jelly-pink));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-tagline {
    font-size:1.25rem; color:var(--text-secondary); margin-bottom:12px;
    font-weight:500;
}
.hero-description {
    font-size:1rem; color:var(--text-muted); max-width:520px; margin:0 auto 32px;
    line-height:1.8;
}
.hero-buttons { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

.hero-scroll {
    position:absolute; bottom:40px; left:50%; transform:translateX(-50%);
    display:flex; flex-direction:column; align-items:center; gap:8px;
    color: var(--text-muted); font-size:0.75rem; letter-spacing:0.1em;
    text-transform:uppercase;
}
.scroll-indicator {
    width:1px; height:30px;
    background: linear-gradient(to bottom, var(--text-muted), transparent);
    animation: scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce { 0%,100% { transform:scaleY(1); opacity:1; } 50% { transform:scaleY(0.5); opacity:0.3; } }

.hero-rings { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.ring {
    position:absolute; border-radius:50%; border:1px solid rgba(168,85,247,0.06);
}
.ring-1 { width:600px; height:600px; top:50%; left:50%; transform:translate(-50%,-50%); animation: ringPulse 8s ease-in-out infinite; }
.ring-2 { width:800px; height:800px; top:50%; left:50%; transform:translate(-50%,-50%); animation: ringPulse 10s ease-in-out infinite 1s; border-color:rgba(45,212,191,0.04); }
.ring-3 { width:1000px; height:1000px; top:50%; left:50%; transform:translate(-50%,-50%); animation: ringPulse 12s ease-in-out infinite 2s; border-color:rgba(236,72,153,0.03); }
@keyframes ringPulse { 0%,100% { transform:translate(-50%,-50%) scale(1); opacity:1; } 50% { transform:translate(-50%,-50%) scale(1.05); opacity:0.5; } }

/* ============================================================
   SECTIONS (shared)
   ============================================================ */
.section { padding:100px 0; position:relative; }

.section-header { text-align:center; margin-bottom:60px; }
.section-tag {
    display:inline-block; font-size:0.75rem; font-weight:600;
    text-transform:uppercase; letter-spacing:0.15em;
    color: var(--jelly-teal); margin-bottom:12px;
}
.section-title {
    font-family: var(--font-heading); font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight:700;
}

/* ============================================================
   ABOUT
   ============================================================ */
.about-content { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.about-text .lead { font-size:1.15rem; color:var(--text-primary); margin-bottom:16px; line-height:1.8; }
.about-text p { color:var(--text-secondary); margin-bottom:12px; }

.features-grid { display:flex; flex-direction:column; gap:16px; }
.feature-card {
    padding:24px; border-radius:16px;
    background: var(--surface); border:1px solid var(--border);
    transition: border-color 0.3s, transform 0.3s var(--ease-spring);
}
.feature-card:hover { border-color:var(--border-hover); transform:translateY(-2px); }
.feature-icon {
    width:40px; height:40px; margin-bottom:12px;
    color: var(--jelly-teal);
}
.feature-icon svg { width:100%; height:100%; }
.feature-card h3 {
    font-family:var(--font-heading); font-size:1rem; font-weight:600; margin-bottom:6px;
}
.feature-card p { font-size:0.88rem; color:var(--text-muted); line-height:1.6; }

@media (max-width:768px) {
    .about-content { grid-template-columns:1fr; gap:40px; }
}

/* ============================================================
   FOUNDERS
   ============================================================ */
.founders-grid { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
.founder-card {
    position:relative; padding:40px 32px; border-radius:20px;
    background: var(--surface); border:1px solid var(--border);
    text-align:center;
    transition: border-color 0.3s, transform 0.4s var(--ease-spring);
    overflow:hidden;
}
.founder-card:hover { border-color:var(--border-hover); transform:translateY(-4px); }

.card-glow {
    position:absolute; top:-50%; left:-50%; width:200%; height:200%;
    background: radial-gradient(circle at 50% 50%, rgba(168,85,247,0.04), transparent 60%);
    pointer-events:none;
}
.founder-card:nth-child(2) .card-glow {
    background: radial-gradient(circle at 50% 50%, rgba(236,72,153,0.04), transparent 60%);
}

.founder-avatar {
    position:relative; width:90px; height:90px; margin:0 auto 20px;
    display:flex; align-items:center; justify-content:center;
    font-size:2.2rem;
}
.avatar-ring {
    position:absolute; inset:-4px; border-radius:50%;
    border:2px solid rgba(168,85,247,0.2);
    animation: ringPulse 4s ease-in-out infinite;
}
.founder-card:nth-child(2) .avatar-ring { border-color:rgba(236,72,153,0.2); }

.avatar-crown { position:absolute; top:-10px; right:-10px; font-size:1.3rem; }

/* Jellyfish avatar for Lexi */
.jelly-avatar { position:relative; }
.jelly-avatar-head {
    width:50px; height:38px;
    background: linear-gradient(135deg, var(--jelly-pink), var(--jelly-purple));
    border-radius: 50% 50% 35% 35%;
    box-shadow: 0 0 20px rgba(236,72,153,0.3);
    animation: jellyFloat 3s ease-in-out infinite;
}
.jelly-avatar-tentacles { display:flex; justify-content:center; gap:2px; margin-top:2px; }
.jelly-avatar-tentacles span {
    width:2px; border-radius:2px;
    background: linear-gradient(to bottom, var(--jelly-pink), transparent);
    animation: tentacleWave 2s ease-in-out infinite;
}
.jelly-avatar-tentacles span:nth-child(1) { height:12px; animation-delay:0s; }
.jelly-avatar-tentacles span:nth-child(2) { height:16px; animation-delay:0.1s; }
.jelly-avatar-tentacles span:nth-child(3) { height:20px; animation-delay:0.2s; }
.jelly-avatar-tentacles span:nth-child(4) { height:16px; animation-delay:0.3s; }
.jelly-avatar-tentacles span:nth-child(5) { height:12px; animation-delay:0.4s; }

.founder-name {
    font-family:var(--font-heading); font-size:1.35rem; font-weight:700; margin-bottom:4px;
}
.founder-realname { font-weight:400; color:var(--text-secondary); font-size:0.9em; }
.founder-role {
    display:block; font-size:0.8rem; color:var(--jelly-teal); font-weight:500;
    margin-bottom:16px;
}
.founder-card:nth-child(2) .founder-role { color:var(--jelly-pink); }

.founder-bio {
    font-size:0.9rem; color:var(--text-secondary); line-height:1.7;
    margin-bottom:10px; text-align:left;
}
.founder-bio-highlight {
    color:var(--text-primary); font-weight:500;
    padding:12px 16px; border-radius:10px;
    background: rgba(168,85,247,0.06);
    border-left:3px solid var(--jelly-purple);
    margin-top:16px;
}
.founder-card:nth-child(2) .founder-bio-highlight {
    background: rgba(236,72,153,0.06);
    border-left-color: var(--jelly-pink);
}

.founder-tags {
    display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-top:20px;
}
.founder-tags span {
    padding:4px 12px; font-size:0.78rem; border-radius:100px;
    background: var(--surface-hover); border:1px solid var(--border);
    color:var(--text-secondary);
}

@media (max-width:768px) {
    .founders-grid { grid-template-columns:1fr; }
}

/* ============================================================
   PROJECTS
   ============================================================ */
.project-showcase { margin-bottom:40px; }
.project-card {
    position:relative; padding:40px; border-radius:24px;
    background: var(--surface); border:1px solid var(--border);
    overflow:hidden;
    transition: border-color 0.3s, transform 0.4s var(--ease-spring);
}
.project-card:hover { border-color: var(--border-hover); transform:translateY(-3px); }
.project-card-featured { border-color: rgba(168,85,247,0.15); }

.project-glow {
    position:absolute; top:-100px; right:-100px; width:400px; height:400px;
    background: radial-gradient(circle, rgba(168,85,247,0.06), transparent 70%);
    pointer-events:none;
}

.project-status {
    display:inline-flex; align-items:center; gap:6px;
    font-size:0.78rem; font-weight:600; text-transform:uppercase;
    letter-spacing:0.08em; color:var(--text-secondary);
    margin-bottom:20px; padding:6px 14px; border-radius:100px;
    background: var(--surface-hover); border:1px solid var(--border);
}
.project-status-live { border-color: rgba(34,197,94,0.2); background: rgba(34,197,94,0.06); color: var(--keeper-green); }

.status-dot {
    width:8px; height:8px; border-radius:50%;
    background: var(--text-muted);
}
.status-dot-live {
    background: var(--keeper-green);
    box-shadow: 0 0 8px var(--keeper-green);
    animation: pulse 2s ease-in-out infinite;
}

.project-header { display:flex; align-items:center; gap:16px; margin-bottom:16px; }
.project-icon { font-size:2.5rem; }
.project-logo { width:56px; height:56px; border-radius:12px; object-fit:cover; }
.project-name {
    font-family:var(--font-heading); font-size:1.8rem; font-weight:700;
}
.project-subtitle { font-size:0.9rem; color:var(--text-secondary); display:block; }

.project-description {
    font-size:1rem; color:var(--text-secondary); line-height:1.8;
    max-width:600px; margin-bottom:28px;
}

.project-features-grid {
    display:grid; grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
    gap:10px; margin-bottom:32px;
}
.feature-pill {
    display:flex; align-items:center; gap:8px;
    padding:10px 14px; border-radius:10px;
    background: rgba(168,85,247,0.04); border:1px solid rgba(168,85,247,0.08);
    font-size:0.88rem; color:var(--text-secondary);
    transition: border-color 0.25s, background 0.25s;
}
.feature-pill:hover { border-color: rgba(168,85,247,0.2); background: rgba(168,85,247,0.08); }
.feature-pill svg { width:16px; height:16px; color:var(--jelly-teal); flex-shrink:0; }

.project-cta { display:flex; align-items:center; gap:16px; flex-wrap:wrap; }
.project-cta-note { font-size:0.85rem; color:var(--text-muted); }

.coming-soon {
    text-align:center; padding:40px 0;
    color:var(--text-muted); font-size:0.95rem;
}
.lab-icons { display:flex; gap:12px; justify-content:center; margin-top:12px; font-size:1.5rem; }

@media (max-width:600px) {
    .project-card { padding:24px; }
    .project-features-grid { grid-template-columns:1fr; }
    .project-name { font-size:1.4rem; }
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }

.contact-lead { font-size:1.05rem; color:var(--text-secondary); line-height:1.8; margin-bottom:28px; }

.contact-email {
    display:flex; align-items:center; gap:16px;
    padding:16px 20px; border-radius:14px;
    background: var(--surface); border:1px solid var(--border);
    margin-bottom:12px;
    transition: border-color 0.25s, transform 0.25s var(--ease-spring);
}
.contact-email:hover { border-color:var(--border-hover); transform:translateX(4px); }
.email-icon { color:var(--jelly-teal); flex-shrink:0; }
.email-icon svg { width:28px; height:28px; }
.email-label { font-size:0.75rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.08em; display:block; }
.email-address { font-size:0.95rem; font-weight:500; color:var(--text-primary); }

.social-section { margin-top:28px; }
.social-label {
    font-size:0.75rem; color:var(--text-muted); text-transform:uppercase;
    letter-spacing:0.1em; margin-bottom:12px; display:block;
}
.social-links { display:flex; gap:10px; }
.social-link {
    width:44px; height:44px; border-radius:12px;
    background: var(--surface); border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    color:var(--text-secondary);
    transition: border-color 0.25s, color 0.25s, transform 0.25s var(--ease-spring);
}
.social-link svg { width:20px; height:20px; }
.social-link:hover { border-color:var(--jelly-purple); color:var(--jelly-purple); transform:translateY(-2px); }

/* Contact Form */
.contact-form {
    display:flex; flex-direction:column; gap:16px;
}
.form-group { display:flex; flex-direction:column; gap:6px; }
.form-group label {
    font-size:0.8rem; font-weight:500; color:var(--text-secondary);
}
.form-group input, .form-group textarea {
    padding:12px 16px; border-radius:10px;
    background: var(--surface); border:1px solid var(--border);
    color: var(--text-primary); font-family:var(--font-body); font-size:0.95rem;
    outline:none; resize:vertical;
    transition: border-color 0.25s;
}
.form-group input:focus, .form-group textarea:focus {
    border-color: var(--jelly-purple);
}
.form-group input::placeholder, .form-group textarea::placeholder {
    color: var(--text-muted);
}

.form-success {
    display:none; align-items:center; gap:10px;
    padding:14px 20px; border-radius:12px;
    background: rgba(34,197,94,0.08); border:1px solid rgba(34,197,94,0.15);
    color: var(--keeper-green); font-size:0.9rem; font-weight:500;
}
.form-success.show { display:flex; }
.form-success svg { width:22px; height:22px; flex-shrink:0; color:var(--keeper-green); }

@media (max-width:768px) {
    .contact-grid { grid-template-columns:1fr; gap:40px; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer {
    padding:60px 0 30px;
    border-top:1px solid var(--border);
}
.footer-main {
    display:flex; justify-content:space-between; align-items:start;
    margin-bottom:40px;
}
.footer-logo {
    font-family:var(--font-heading); font-size:1.1rem; font-weight:700;
    display:block; margin-bottom:8px;
}
.footer-brand p { font-size:0.88rem; color:var(--text-muted); }

.footer-links { display:flex; gap:24px; }
.footer-links a {
    font-size:0.88rem; color:var(--text-secondary);
    transition: color 0.25s;
}
.footer-links a:hover { color:var(--text-primary); }

.footer-bottom {
    text-align:center; padding-top:24px; border-top:1px solid var(--border);
}
.footer-bottom p { font-size:0.8rem; color:var(--text-muted); }
.credits { margin-top:4px; }

@media (max-width:600px) {
    .footer-main { flex-direction:column; gap:24px; }
    .footer-links { flex-wrap:wrap; gap:16px; }
}

/* ============================================================
   SCROLL ANIMATIONS (GSAP will add these classes)
   ============================================================ */
.reveal {
    opacity:0; transform:translateY(30px);
    transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
}
.reveal.active { opacity:1; transform:translateY(0); }

/* ============================================================
   SELECTION
   ============================================================ */
::selection { background:rgba(168,85,247,0.25); color:white; }
