:root{
  --bg:#07080c;
  --surface:#0f1117;
  --card:#141720;
  --border:rgba(255,255,255,0.06);
  --accent:#00e5ff;
  --accent2:#7c3aed;
  --gold:#f59e0b;
  --white:#f0f4ff;
  --muted:#6b7280;
  --radius:18px;
  --font-display:'Instrument Serif',serif;
  --font-body:'Syne',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--white);
  font-family:var(--font-body);
  font-weight:400;
  line-height:1.65;
  overflow-x:hidden;
}

/* GRAIN */
body::after{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  pointer-events:none;z-index:9999;
}

/* CURSOR DOT */
.cursor{
  position:fixed;width:8px;height:8px;
  background:var(--accent);border-radius:50%;
  pointer-events:none;z-index:9998;
  transition:transform 0.1s;
  mix-blend-mode:screen;
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;justify-content:space-between;align-items:center;
  padding:1.1rem 5vw;
  background:rgba(7,8,12,0.8);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
}
.nav-logo{
  font-family:var(--font-display);
  font-size:1.25rem;font-style:italic;
  color:var(--white);text-decoration:none;
  letter-spacing:-0.01em;
}
.nav-logo span{color:var(--accent);}
.nav-links{display:flex;gap:2rem;list-style:none;}
.nav-links a{
  color:var(--muted);text-decoration:none;
  font-size:0.78rem;letter-spacing:0.12em;text-transform:uppercase;
  transition:color 0.2s;font-weight:600;
}
.nav-links a:hover{color:var(--accent);}
.nav-cta{
  padding:0.55rem 1.4rem;border-radius:100px;
  background:var(--accent);color:var(--bg);
  font-size:0.78rem;font-weight:700;letter-spacing:0.08em;
  text-decoration:none;font-family:var(--font-body);
  transition:all 0.2s;
}
.nav-cta:hover{background:#33ecff;transform:translateY(-1px);}

/* HERO */
.hero{
  min-height:100vh;
  display:grid;grid-template-columns:1.1fr 0.9fr;
  align-items:center;gap:4rem;
  padding:7rem 5vw 4rem;
  position:relative;overflow:hidden;
}
.hero-glow{
  position:absolute;top:-20%;right:-10%;
  width:70vw;height:120%;
  background:radial-gradient(ellipse at 60% 40%, rgba(0,229,255,0.05) 0%, rgba(124,58,237,0.04) 40%, transparent 70%);
  pointer-events:none;
}
.hero-glow2{
  position:absolute;bottom:-30%;left:-10%;
  width:50vw;height:80%;
  background:radial-gradient(ellipse at 40% 60%, rgba(124,58,237,0.06) 0%, transparent 60%);
  pointer-events:none;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:0.6rem;
  font-size:0.72rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.5rem;
  opacity:0;animation:slideUp 0.7s 0.1s forwards;
}
.hero-eyebrow::before{content:'';width:1.5rem;height:1px;background:var(--accent);}
h1{
  font-family:var(--font-display);
  font-size:clamp(3rem,5.5vw,5.5rem);
  font-weight:400;line-height:1.0;
  color:var(--white);
  margin-bottom:1.5rem;
  opacity:0;animation:slideUp 0.7s 0.2s forwards;
}
h1 em{font-style:italic;color:var(--accent);}
.hero-sub{
  font-size:1rem;color:var(--muted);
  max-width:460px;margin-bottom:2.5rem;
  opacity:0;animation:slideUp 0.7s 0.35s forwards;
  line-height:1.75;
}
.hero-actions{
  display:flex;gap:1rem;flex-wrap:wrap;
  opacity:0;animation:slideUp 0.7s 0.5s forwards;
}
.btn{
  padding:0.8rem 1.8rem;border-radius:100px;
  font-size:0.82rem;font-weight:700;letter-spacing:0.06em;
  text-decoration:none;cursor:pointer;border:none;
  font-family:var(--font-body);transition:all 0.25s;
}
.btn-cyan{background:var(--accent);color:var(--bg);}
.btn-cyan:hover{background:#33ecff;transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,229,255,0.25);}
.btn-ghost{background:transparent;color:var(--white);border:1px solid var(--border);}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);}
.hero-links{
  display:flex;gap:1rem;margin-top:2rem;
  opacity:0;animation:slideUp 0.7s 0.65s forwards;
}
.hero-link{
  display:flex;align-items:center;gap:0.4rem;
  color:var(--muted);text-decoration:none;font-size:0.78rem;
  transition:color 0.2s;font-weight:600;
}
.hero-link:hover{color:var(--accent);}

/* PHOTO SIDE */
.hero-visual{
  position:relative;
  opacity:0;animation:fadeIn 1s 0.4s forwards;
}
.photo-frame{
  position:relative;
  border-radius:28px;overflow:hidden;
}
.photo-frame::before{
  content:'';position:absolute;inset:-1px;
  background:linear-gradient(135deg,rgba(0,229,255,0.3),transparent 50%,rgba(124,58,237,0.2));
  border-radius:28px;z-index:2;pointer-events:none;
}
.photo-frame img{
  width:100%;height:580px;
  object-fit:cover;object-position:center top;
  display:block;filter:contrast(1.05);
  border-radius:28px;
}
.photo-overlay{
  position:absolute;bottom:0;left:0;right:0;
  height:35%;
  background:linear-gradient(to top, var(--bg), transparent);
  z-index:3;
}
.float-card{
  position:absolute;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1rem 1.2rem;
  backdrop-filter:blur(10px);
  z-index:10;
}
.float-card-1{bottom:3rem;left:-2rem;}
.float-card-2{top:2.5rem;right:-1.5rem;}
.fc-label{font-size:0.68rem;color:var(--muted);letter-spacing:0.08em;text-transform:uppercase;margin-bottom:0.3rem;}
.fc-value{font-size:1.2rem;font-weight:800;color:var(--accent);}
.fc-sub{font-size:0.72rem;color:var(--muted);}

/* MARQUEE STRIP */
.marquee-wrap{
  padding:1.2rem 0;
  background:linear-gradient(90deg,rgba(0,229,255,0.08),rgba(124,58,237,0.08));
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  overflow:hidden;white-space:nowrap;
}
.marquee-track{
  display:inline-flex;gap:3rem;
  animation:marquee 30s linear infinite;
}
.marquee-item{
  font-size:0.78rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--muted);display:flex;align-items:center;gap:0.75rem;
}
.marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--accent);}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* SECTIONS */
section{padding:7rem 5vw;position:relative;}
.section-tag{
  font-size:0.7rem;font-weight:700;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;align-items:center;gap:0.5rem;
  margin-bottom:1rem;
}
.section-tag::before{content:'';width:1.2rem;height:1px;background:var(--accent);}
h2{
  font-family:var(--font-display);
  font-size:clamp(2rem,3.5vw,3.2rem);
  font-weight:400;color:var(--white);
  line-height:1.1;margin-bottom:3.5rem;
}
h2 em{font-style:italic;color:var(--accent);}

/* SERVICES SECTION */
.services-section{
  background:var(--surface);
}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.service-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem;
  transition:all 0.3s;
}
.service-card:hover{
  border-color:rgba(0,229,255,0.2);
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(0,0,0,0.4);
}
.service-icon{
  font-size:2.2rem;
  margin-bottom:1rem;
}
.service-title{
  font-family:var(--font-display);
  font-size:1.4rem;
  color:var(--white);
  margin-bottom:0.8rem;
  font-weight:400;
}
.service-desc{
  font-size:0.9rem;
  color:var(--muted);
  line-height:1.7;
}

/* BEEPR PROJECT — FEATURED */
.featured{background:var(--surface);}
.beepr-wrap{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5rem;align-items:center;
}
.beepr-screens{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1rem;
}
.beepr-screen{
  border-radius:16px;overflow:hidden;
  border:1px solid var(--border);
  transition:transform 0.3s;
}
.beepr-screen:hover{transform:scale(1.03);}
.beepr-screen img{width:100%;display:block;height:220px;object-fit:cover;object-position:top center;}
.beepr-screen:first-child{
  grid-column:1/-1;
}
.beepr-screen:first-child img{height:280px;}
.featured-label{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(0,229,255,0.08);border:1px solid rgba(0,229,255,0.2);
  color:var(--accent);font-size:0.72rem;font-weight:700;letter-spacing:0.12em;
  text-transform:uppercase;padding:0.3rem 0.9rem;border-radius:100px;
  margin-bottom:1.2rem;
}
.featured-meta{
  display:flex;
  flex-wrap:wrap;
  gap:0.5rem;
  margin-bottom:1rem;
}
.beepr-title{
  font-family:var(--font-display);font-size:2.8rem;
  color:var(--white);font-weight:400;line-height:1.05;
  margin-bottom:0.5rem;
}
.beepr-title em{font-style:italic;color:#ff2d78;}
.beepr-desc{color:var(--muted);font-size:0.95rem;margin-bottom:2rem;line-height:1.75;}
.metrics-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1rem;margin-bottom:2rem;
}
.metric{
  background:var(--card);border:1px solid var(--border);
  border-radius:12px;padding:1rem;
  text-align:center;transition:border-color 0.2s;
}
.metric:hover{border-color:rgba(0,229,255,0.3);}
.metric-val{
  font-family:var(--font-display);font-size:1.8rem;
  color:var(--accent);font-weight:400;display:block;
}
.metric-lab{font-size:0.7rem;color:var(--muted);letter-spacing:0.06em;}
.contrib-list{display:flex;flex-direction:column;gap:0.6rem;margin-bottom:2rem;}
.contrib-item{
  display:flex;align-items:flex-start;gap:0.7rem;
  font-size:0.88rem;color:var(--muted);
}
.contrib-item::before{
  content:'\2192';color:var(--accent);flex-shrink:0;
  font-size:0.9rem;margin-top:0.05rem;
}
.stack-pills{display:flex;flex-wrap:wrap;gap:0.5rem;}
.pill{
  font-size:0.72rem;font-weight:600;letter-spacing:0.06em;
  padding:0.3rem 0.8rem;border-radius:100px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);color:var(--muted);
  transition:all 0.2s;
}
.pill:hover{border-color:var(--accent);color:var(--accent);}
.app-store-link{
  display:inline-flex;align-items:center;gap:0.5rem;
  background:#ff2d78;color:white;
  padding:0.6rem 1.2rem;border-radius:10px;
  text-decoration:none;font-size:0.8rem;font-weight:700;
  transition:all 0.2s;margin-top:1.5rem;
}
.app-store-link:hover{background:#ff5499;transform:translateY(-1px);}

/* PROJECTS GRID */
.projects-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
}
.proj-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.8rem;
  transition:all 0.3s;
  text-decoration:none;
  display:block;
  position:relative;
  overflow:hidden;
}
.proj-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s;
}
.proj-card:hover::before{transform:scaleX(1);}
.proj-card:hover{border-color:rgba(0,229,255,0.15);transform:translateY(-4px);box-shadow:0 16px 48px rgba(0,0,0,0.4);}
.proj-card.highlight{border-color:rgba(245,158,11,0.2);}
.proj-card.highlight::before{background:linear-gradient(90deg,var(--gold),#fbbf24);}
.proj-emoji{font-size:1.6rem;margin-bottom:1rem;display:block;}
.proj-tag{
  font-size:0.67rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  color:var(--accent);margin-bottom:0.6rem;
}
.proj-card.highlight .proj-tag{color:var(--gold);}
.proj-title{
  font-family:var(--font-display);font-size:1.2rem;
  color:var(--white);margin-bottom:0.5rem;font-weight:400;
}
.proj-desc{font-size:0.84rem;color:var(--muted);line-height:1.65;margin-bottom:1.2rem;}
.proj-outcome{
  font-size:0.78rem;font-weight:700;
  color:var(--gold);margin-bottom:1rem;
}
.proj-stack{display:flex;flex-wrap:wrap;gap:0.4rem;}
.proj-tech{
  font-size:0.68rem;letter-spacing:0.05em;
  padding:0.18rem 0.55rem;border-radius:100px;
  border:1px solid rgba(255,255,255,0.08);color:var(--muted);
}
.proj-link{
  display:inline-flex;align-items:center;gap:0.3rem;
  font-size:0.75rem;font-weight:600;color:var(--accent);
  text-decoration:none;margin-top:1rem;
  transition:gap 0.2s;
}
.proj-link:hover{gap:0.5rem;}

/* CASE STUDIES SECTION */
.case-studies-section{
  background:var(--bg);
}
.case-studies-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.case-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:2rem;
  transition:all 0.3s;
}
.case-card:hover{
  border-color:rgba(0,229,255,0.2);
  transform:translateY(-4px);
  box-shadow:0 16px 48px rgba(0,0,0,0.4);
}
.case-emoji{
  font-size:2rem;
  margin-bottom:0.8rem;
}
.case-title{
  font-family:var(--font-display);
  font-size:1.5rem;
  color:var(--white);
  margin-bottom:1.5rem;
  font-weight:400;
}
.case-block{
  margin-bottom:1.2rem;
}
.case-label{
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:0.4rem;
}
.case-text{
  font-size:0.9rem;
  color:var(--muted);
  line-height:1.7;
}
.case-result{
  color:var(--gold);
  font-weight:700;
}
.case-stack{
  display:flex;
  flex-wrap:wrap;
  gap:0.4rem;
  margin-top:1.5rem;
}
.case-metrics{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0.8rem;
  margin:1.2rem 0 1.8rem;
}
.case-metric{
  background:rgba(255,255,255,0.03);
  border:1px solid rgba(255,255,255,0.05);
  border-radius:12px;
  padding:0.9rem 0.7rem;
  text-align:center;
}
.case-metric-val{
  font-family:var(--font-display);
  font-size:1.7rem;
  font-weight:400;
  color:var(--white);
  margin-bottom:0.2rem;
}
.case-metric-lab{
  font-size:0.72rem;
  color:var(--muted);
  letter-spacing:0.05em;
}

/* SHOPIFY / CLIENT WORK */
.clients-section{background:var(--surface);}
.clients-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
}
.client-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:14px;padding:1.4rem;
  transition:all 0.25s;text-decoration:none;
}
.client-card:hover{border-color:rgba(0,229,255,0.2);transform:translateY(-3px);}
.client-icon{font-size:1.4rem;margin-bottom:0.7rem;display:block;}
.client-name{font-size:0.88rem;font-weight:700;color:var(--white);margin-bottom:0.25rem;}
.client-type{font-size:0.75rem;color:var(--muted);}

/* SKILLS */
.skills-section{
  background:var(--bg);
}
.skills-wrap{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
}
.skill-group-title{
  font-size:0.75rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;
  color:var(--muted);margin-bottom:1.2rem;
}
.skill-bars{display:flex;flex-direction:column;gap:1rem;}
.skill-row{display:flex;flex-direction:column;gap:0.4rem;}
.skill-top{display:flex;justify-content:space-between;align-items:center;}
.skill-name{font-size:0.85rem;font-weight:600;color:var(--white);}
.skill-pct{font-size:0.75rem;color:var(--accent);font-weight:700;}
.skill-track{
  height:3px;background:rgba(255,255,255,0.06);
  border-radius:100px;overflow:hidden;
}
.skill-fill{
  height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));
  border-radius:100px;width:0;
  transition:width 1.2s cubic-bezier(0.4,0,0.2,1);
}
.tech-cloud{display:flex;flex-wrap:wrap;gap:0.6rem;}
.tech-chip{
  padding:0.45rem 1rem;border-radius:100px;
  border:1px solid var(--border);
  font-size:0.78rem;font-weight:600;color:var(--muted);
  transition:all 0.2s;cursor:default;
}
.tech-chip:hover{border-color:var(--accent);color:var(--accent);background:rgba(0,229,255,0.04);}

/* TECH SECTION */
.tech-section{
  background:var(--surface);
}
.tech-row{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  justify-content:center;
  padding:2rem;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
}
.tech-item{
  font-family:var(--font-body);
  font-size:1.1rem;
  font-weight:700;
  color:var(--white);
  padding:0.6rem 1.4rem;
  border-radius:100px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.06);
  letter-spacing:0.05em;
  transition:all 0.2s;
}
.tech-item:hover{
  border-color:rgba(0,229,255,0.3);
  background:rgba(0,229,255,0.08);
  color:var(--accent);
}

/* EXPERIENCE */
.exp-section{background:var(--surface);}
.exp-grid{display:flex;flex-direction:column;gap:0;}
.exp-item{
  display:grid;grid-template-columns:140px 1fr;
  gap:2.5rem;border-bottom:1px solid var(--border);
  padding:2.5rem 0;
}
.exp-item:last-child{border-bottom:none;}
.exp-date{
  font-size:0.78rem;font-weight:600;color:var(--muted);
  letter-spacing:0.06em;padding-top:0.15rem;
}
.exp-dot{
  display:inline-block;width:6px;height:6px;
  border-radius:50%;background:var(--accent);
  margin-right:0.5rem;
}
.exp-role{
  font-family:var(--font-display);font-size:1.4rem;
  color:var(--white);font-weight:400;margin-bottom:0.2rem;
}
.exp-company{font-size:0.85rem;color:var(--accent);font-weight:600;margin-bottom:0.75rem;}
.exp-desc{font-size:0.88rem;color:var(--muted);line-height:1.7;}
.exp-tags{display:flex;flex-wrap:wrap;gap:0.4rem;margin-top:0.9rem;}

/* ABOUT */
.about-section{background:var(--bg);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;}
.about-img-wrap{
  position:relative;
  border-radius:24px;overflow:hidden;
}
.about-img-wrap img{
  width:100%;height:520px;
  object-fit:cover;object-position:center top;
  display:block;filter:grayscale(20%) contrast(1.05);
  border-radius:24px;
}
.about-img-wrap::after{
  content:'';position:absolute;
  inset:0;border-radius:24px;
  background:linear-gradient(135deg,rgba(0,229,255,0.05),transparent);
}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2.5rem;}
.a-stat{
  background:var(--card);border:1px solid var(--border);
  border-radius:14px;padding:1.2rem;
  transition:border-color 0.2s;
}
.a-stat:hover{border-color:rgba(0,229,255,0.25);}
.a-stat-n{
  font-family:var(--font-display);font-size:2rem;
  color:var(--accent);display:block;font-weight:400;
}
.a-stat-l{font-size:0.78rem;color:var(--muted);}
.about-text p{font-size:0.96rem;color:var(--muted);margin-bottom:1rem;line-height:1.8;}

/* FINAL CTA */
.cta-final{
  background:var(--bg);
  text-align:center;
}
.cta-final h2{
  margin-bottom:2rem;
}

/* CONTACT */
.contact-section{background:var(--surface);}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;}
.contact-form{display:flex;flex-direction:column;gap:1.1rem;}
.f-group{display:flex;flex-direction:column;gap:0.35rem;}
label{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);}
input,textarea{
  background:var(--card);border:1px solid var(--border);
  border-radius:10px;padding:0.8rem 1rem;
  color:var(--white);font-family:var(--font-body);
  font-size:0.9rem;outline:none;resize:vertical;
  transition:border-color 0.2s;
}
input:focus,textarea:focus{border-color:var(--accent);}
textarea{min-height:120px;}
.contact-info{display:flex;flex-direction:column;gap:1.2rem;}
.c-item{
  display:flex;align-items:center;gap:1rem;
  padding:1.1rem;background:var(--card);
  border:1px solid var(--border);border-radius:14px;
  text-decoration:none;transition:all 0.2s;
}
.c-item:hover{border-color:rgba(0,229,255,0.25);transform:translateX(4px);}
.c-icon{
  width:44px;height:44px;border-radius:10px;
  background:rgba(0,229,255,0.08);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.c-label{font-size:0.68rem;color:var(--muted);letter-spacing:0.08em;text-transform:uppercase;}
.c-val{font-size:0.88rem;color:var(--white);font-weight:600;}
.social-row{display:flex;gap:0.8rem;margin-top:1rem;flex-wrap:wrap;}
.social-btn{
  display:inline-flex;align-items:center;gap:0.4rem;
  padding:0.55rem 1.1rem;border-radius:100px;
  border:1px solid var(--border);color:var(--muted);
  text-decoration:none;font-size:0.75rem;font-weight:600;
  transition:all 0.2s;
}
.social-btn:hover{border-color:var(--accent);color:var(--accent);}

/* FOOTER */
footer{
  border-top:1px solid var(--border);
  padding:1.8rem 5vw;
  display:flex;justify-content:space-between;align-items:center;
  color:var(--muted);font-size:0.78rem;
}
footer a{color:var(--accent);text-decoration:none;}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease;}
.reveal.visible{opacity:1;transform:none;}

/* ANIMATIONS */
@keyframes slideUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* RESPONSIVE */
@media(max-width:1024px){
  .projects-grid{grid-template-columns:1fr 1fr;}
  .services-grid{grid-template-columns:1fr 1fr;}
  .case-studies-grid{grid-template-columns:1fr 1fr;}
  .case-metrics{grid-template-columns:1fr;}
  .clients-grid{grid-template-columns:1fr 1fr;}
  .beepr-wrap{grid-template-columns:1fr;gap:3rem;}
  .beepr-screens{grid-template-columns:repeat(4,1fr);}
  .beepr-screen:first-child{grid-column:auto;}
  .beepr-screen:first-child img,.beepr-screen img{height:180px;}
}
@media(max-width:768px){
  .hero{grid-template-columns:1fr;padding-top:6rem;}
  .hero-visual{order:-1;}
  .photo-frame img{height:340px;}
  .float-card-1{display:none;}
  nav .nav-links{display:none;}
  .about-grid,.contact-grid,.skills-wrap{grid-template-columns:1fr;gap:2.5rem;}
  .projects-grid{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:1fr;}
  .case-studies-grid{grid-template-columns:1fr;}
  .case-metrics{grid-template-columns:1fr;}
  .clients-grid{grid-template-columns:1fr 1fr;}
  .exp-item{grid-template-columns:1fr;gap:0.5rem;}
  .metrics-row{grid-template-columns:1fr 1fr 1fr;}
}
