:root{--bg:#050b16;--bg2:#0b1024;--text:#f6f3ff;--muted:#c8c3dc;--cyan:#68f7ff;--blue:#5c7cff;--purple:#a56bff;--card:rgba(255,255,255,.075);--line:rgba(255,255,255,.16)}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,system-ui,sans-serif;background:radial-gradient(circle at 0 0,rgba(90,0,180,.55),transparent 34%),radial-gradient(circle at 100% 0,rgba(0,210,230,.32),transparent 33%),linear-gradient(180deg,#080a18 0%,#050b16 65%,#03070f 100%);color:var(--text);line-height:1.6;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;inset:0;z-index:-3;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:64px 64px;pointer-events:none;mask-image:linear-gradient(to bottom,black,transparent 85%)}body:after{content:"";position:fixed;width:520px;height:520px;right:-180px;top:16%;z-index:-2;background:radial-gradient(circle,rgba(104,247,255,.22),transparent 66%);filter:blur(28px);animation:ambientOrb 12s ease-in-out infinite alternate;pointer-events:none}body.no-scroll{overflow:hidden}@keyframes ambientOrb{from{transform:translate3d(0,0,0) scale(1);opacity:.7}to{transform:translate3d(-80px,120px,0) scale(1.18);opacity:.95}}
a{color:inherit;text-decoration:none}img,video,iframe{max-width:100%}.container{width:min(1180px,92%);margin:auto}.section{position:relative;padding:92px 0}.site-header{position:fixed;top:0;left:0;right:0;z-index:20;background:rgba(5,10,22,.72);backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}.nav{height:72px;display:flex;align-items:center;justify-content:space-between}.logo{font-size:24px;font-weight:900;letter-spacing:-.04em}.logo span,.gradient{color:var(--cyan)}.nav-links{display:flex;gap:24px;color:var(--muted);font-weight:700}.nav-links a{position:relative;transition:.25s ease}.nav-links a:hover{color:var(--cyan)}.nav-links a:after{content:"";position:absolute;left:0;bottom:-8px;width:0;height:2px;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--purple));transition:.25s ease}.nav-links a:hover:after{width:100%}.nav-toggle{display:none}
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding-top:120px;overflow:hidden}.hero:before{content:"";position:absolute;width:560px;height:560px;left:-200px;top:15%;background:radial-gradient(circle,rgba(165,107,255,.38),transparent 62%);filter:blur(22px);animation:heroFloat 9s ease-in-out infinite alternate;pointer-events:none}.hero:after{content:"";position:absolute;width:420px;height:420px;right:9%;bottom:8%;background:radial-gradient(circle,rgba(104,247,255,.2),transparent 66%);filter:blur(18px);animation:heroFloat 11s ease-in-out infinite alternate-reverse;pointer-events:none}@keyframes heroFloat{from{transform:translateY(0) translateX(0)}to{transform:translateY(-36px) translateX(42px)}}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:72px;align-items:center}.eyebrow,.section-label,.tag{display:inline-block;color:var(--cyan);font-size:13px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.eyebrow{border:1px solid rgba(104,247,255,.38);padding:8px 14px;border-radius:999px;background:rgba(104,247,255,.08)}h1{font-size:clamp(56px,8vw,104px);line-height:.94;margin:28px 0;letter-spacing:-.08em;background:linear-gradient(90deg,#fff 0%,#fff 48%,var(--cyan) 70%,var(--purple) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-subtitle{max-width:690px;font-size:clamp(20px,2.3vw,28px);color:#d8d4e7;margin:0 0 34px}.btn,.text-link{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-weight:900;transition:.35s ease}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}.btn{padding:16px 22px;border:1px solid var(--line)}.btn.primary{background:linear-gradient(135deg,var(--purple),#15d4ff);box-shadow:0 0 50px rgba(104,247,255,.15)}.btn.secondary{background:rgba(255,255,255,.05)}.btn:hover,.text-link:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.25),0 0 18px rgba(104,247,255,.1)}.hero-card{position:relative;border:1px solid var(--line);border-radius:32px;background:linear-gradient(145deg,rgba(255,255,255,.14),rgba(255,255,255,.035));box-shadow:0 30px 90px rgba(0,0,0,.38);backdrop-filter:blur(18px);padding:18px;overflow:hidden}.profile-frame{border-radius:26px;overflow:hidden;border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 0 70px rgba(104,247,255,.16)}.profile-photo{display:block;width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center;filter:saturate(1.05) contrast(1.05);transition:transform .9s ease,filter .9s ease}.profile-card:hover .profile-photo{transform:scale(1.015);filter:saturate(1.08) contrast(1.05)}.status-card{position:absolute;left:28px;bottom:28px;background:rgba(5,10,22,.72);border:1px solid var(--line);border-radius:999px;padding:10px 14px;font-weight:800;font-size:13px;backdrop-filter:blur(14px)}.status-dot{display:inline-block;width:9px;height:9px;border-radius:50%;background:#52ff99;margin-right:8px;box-shadow:0 0 14px #52ff99}
.narrow{max-width:900px}.section h2{font-size:clamp(36px,5vw,62px);line-height:1.02;letter-spacing:-.06em;margin:12px 0 20px}.section p{color:var(--muted);font-size:18px}.section-heading{margin-bottom:34px}.projects-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;overflow:visible}.project-card,.skill-card,.media-placeholder,.contact-card{border:1px solid var(--line);border-radius:28px;background:linear-gradient(145deg,rgba(255,255,255,.09),rgba(255,255,255,.035));overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.25)}
.project-card{position:relative;transform-origin:center;transition:transform .75s cubic-bezier(.22,.61,.36,1),box-shadow .75s ease,border-color .75s ease,filter .75s ease;will-change:transform}.project-card:after{content:"";position:absolute;inset:0;border-radius:28px;background:linear-gradient(130deg,transparent,rgba(104,247,255,.08),transparent);opacity:0;transition:opacity .45s ease;pointer-events:none}.project-card:hover{transform:translateY(-2px) scale(1.008);border-color:rgba(104,247,255,.35);box-shadow:0 15px 35px rgba(0,0,0,.22),0 0 12px rgba(104,247,255,.08);filter:brightness(1.01);z-index:10}.project-card:hover:after{opacity:1}.project-media{width:100%;aspect-ratio:16/9;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(0,217,255,.18),rgba(123,77,255,.18));color:#fff;font-weight:900;letter-spacing:.13em;text-transform:uppercase}.project-media img,.project-media video,.project-media iframe{width:100%;height:100%;display:block;object-fit:cover;border:0}.project-media img,.project-media video{transition:transform 1.1s ease,filter 1.1s ease}.project-card:hover .project-media img,.project-card:hover .project-media video{transform:scale(1.005);filter:brightness(1.015)}.project-card.media-contain .project-media img{object-fit:contain;background:#07101d}.project-body{padding:26px}.project-body h3{font-size:28px;margin:12px 0}.project-body ul{color:var(--muted);padding-left:18px}.card-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}.text-link{padding:10px 14px;background:rgba(255,255,255,.08);border:1px solid var(--line);font-size:14px}
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.skill-card{padding:24px;transition:transform .6s ease,box-shadow .6s ease,border-color .6s ease}.skill-card:hover{transform:translateY(-3px);border-color:rgba(104,247,255,.25);box-shadow:0 16px 44px rgba(0,0,0,.24),0 0 18px rgba(104,247,255,.06)}.skill-card h3{margin-top:0}.video-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;margin-top:32px}.video-card{aspect-ratio:16/9;border:1px solid var(--line);border-radius:28px;overflow:hidden;background:rgba(255,255,255,.06);box-shadow:0 24px 70px rgba(0,0,0,.22)}.video-card iframe{width:100%;height:100%;border:0;display:block}.screenshots-slider{position:relative;margin-top:30px;overflow:visible;padding-top:25px;padding-bottom:25px}.screenshots-track{display:flex;gap:28px;overflow-x:auto;overflow-y:visible;scroll-behavior:smooth;scrollbar-width:none;padding:25px 15px}.screenshots-track::-webkit-scrollbar{display:none}.screenshots-track img{width:560px;height:315px;object-fit:contain;object-position:center;background:#07101d;border-radius:22px;border:1px solid rgba(255,255,255,.18);flex:0 0 auto;cursor:pointer;transition:transform .45s ease,box-shadow .45s ease,border-color .45s ease,filter .45s ease,opacity .45s ease}.screenshots-track:hover img{opacity:.72}.screenshots-track img:hover{opacity:1;transform:scale(1.018);border-color:rgba(104,247,255,.72);filter:brightness(1.05) contrast(1.03);box-shadow:0 18px 38px rgba(0,0,0,.38),0 0 24px rgba(104,247,255,.18);z-index:10;position:relative}.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:48px;height:48px;border-radius:50%;border:1px solid var(--line);background:rgba(5,10,22,.82);color:white;font-size:34px;line-height:1;cursor:pointer;backdrop-filter:blur(10px);transition:.25s ease}.slider-btn:hover{background:rgba(104,247,255,.14);transform:translateY(-50%) scale(1.04)}.slider-btn.prev{left:-22px}.slider-btn.next{right:-22px}
.contact-card{padding:42px;text-align:center}.email-link{display:inline-block;font-size:24px;font-weight:900;color:var(--cyan);margin:10px 0 20px}.social-links{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;color:var(--muted);font-weight:800}.social-links a{padding:8px 10px;border-radius:999px;transition:.25s ease}.social-links a:hover{color:var(--cyan);background:rgba(255,255,255,.06)}.footer{padding:32px 0;border-top:1px solid var(--line);color:var(--muted)}.lightbox{display:none;position:fixed;z-index:9999;inset:0;background:rgba(0,0,0,.95);justify-content:center;align-items:center}.lightbox.show{display:flex}.lightbox img{max-width:92%;max-height:88%;object-fit:contain;border-radius:12px}.lightbox-close{position:absolute;top:25px;right:40px;color:white;font-size:40px;cursor:pointer}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.5);color:white;font-size:32px;cursor:pointer;z-index:10000;transition:.25s ease}.lightbox-nav:hover{background:rgba(255,255,255,.15)}.prev-img{left:40px}.next-img{right:40px}.zoomable-image{cursor:pointer}.cursor-glow{position:fixed;left:0;top:0;width:90px;height:90px;border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(104,247,255,.05),transparent 75%);filter:blur(14px);mix-blend-mode:screen}#backToTop{position:fixed;right:30px;bottom:30px;width:56px;height:56px;border:none;border-radius:50%;background:rgba(104,247,255,.15);border:1px solid rgba(104,247,255,.25);color:white;font-size:24px;cursor:pointer;backdrop-filter:blur(10px);opacity:0;visibility:hidden;transition:.25s ease;z-index:999}#backToTop.show{opacity:1;visibility:visible}#backToTop:hover{transform:translateY(-4px);background:rgba(104,247,255,.25);box-shadow:0 0 25px rgba(104,247,255,.25)}
.reveal,.project-card,.skill-card,.video-card,.contact-card{opacity:0;transform:translateY(34px);filter:blur(10px);transition:opacity .35s ease,transform .35s ease,filter .35s ease,box-shadow .75s ease,border-color .75s ease}.reveal.is-visible,.project-card.is-visible,.skill-card.is-visible,.video-card.is-visible,.contact-card.is-visible{opacity:1;transform:translateY(0);filter:blur(0)}@media(pointer:coarse){.cursor-glow{display:none}}@media(max-width:860px){.hero-grid,.projects-grid,.skills-grid{grid-template-columns:1fr}.nav-toggle{display:block;border:1px solid var(--line);color:var(--text);background:rgba(255,255,255,.06);border-radius:10px;padding:6px 10px;font-size:20px}.nav-links{display:none;position:absolute;left:4%;right:4%;top:78px;flex-direction:column;gap:8px;padding:16px;border:1px solid var(--line);border-radius:20px;background:rgba(5,10,22,.96)}.nav-links.open{display:flex}.hero{padding-top:110px}h1{font-size:58px}.hero-subtitle{font-size:20px}.section{padding:64px 0}.video-grid{grid-template-columns:1fr}.screenshots-track img{width:280px;height:158px}.slider-btn.prev{left:4px}.slider-btn.next{right:4px}.lightbox-nav{width:46px;height:46px;font-size:24px}.prev-img{left:12px}.next-img{right:12px}}
.stats-section {
  padding-top: 40px;
  padding-bottom: 40px;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}

.stat-card {
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 28px 22px;
  text-align: center;
  background:
    radial-gradient(circle at top, rgba(104,247,255,.12), transparent 55%),
    linear-gradient(145deg, rgba(255,255,255,.09), rgba(255,255,255,.035));
  box-shadow: 0 20px 50px rgba(0,0,0,.22);
}

.stat-number {
  display: block;
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1;
  font-weight: 900;
  letter-spacing: -0.05em;
  color: var(--cyan);
  margin-bottom: 12px;
}

.stat-card p {
  margin: 0;
  color: var(--muted);
  font-size: 16px;
  font-weight: 700;
}

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

@media(max-width: 520px) {
  .stats-grid {
    grid-template-columns: 1fr;
  }
}
.timeline {
  position: relative;
  margin-top: 40px;
  padding-left: 30px;
}

.timeline::before {
  content: "";
  position: absolute;
  left: 7px;
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    to bottom,
    var(--cyan),
    var(--purple)
  );
}

.timeline-item {
  position: relative;
  margin-bottom: 45px;
  padding-left: 30px;
}

.timeline-item::before {
  content: "";
  position: absolute;
  left: -1px;
  top: 8px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 18px rgba(104,247,255,.8);
}

.timeline-year {
  display: inline-block;
  color: var(--cyan);
  font-weight: 900;
  margin-bottom: 8px;
}

.timeline-item h3 {
  margin: 0 0 8px;
  font-size: 24px;
}

.timeline-item p {
  margin: 0;
  color: var(--muted);
}
.project-filters{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:24px;
}

.filter-btn{
  padding:10px 16px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  color:var(--muted);
  font-weight:900;
  cursor:pointer;
  transition:.25s ease;
}

.filter-btn:hover,
.filter-btn.active{
  color:white;
  border-color:rgba(104,247,255,.45);
  background:rgba(104,247,255,.14);
  box-shadow:0 0 22px rgba(104,247,255,.12);
}

.project-card.hidden{
  display:none;
}
.footer {
  margin-top: 80px;
  border-top: 1px solid var(--line);
  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,.02),
      rgba(255,255,255,.01)
    );
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 50px;
  padding: 70px 0 40px;
}

.footer-logo {
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -.05em;
  margin-bottom: 18px;
}

.footer-logo span {
  color: var(--cyan);
}

.footer-col h4 {
  margin: 0 0 18px;
  font-size: 18px;
}

.footer-col p {
  color: var(--muted);
  margin: 0;
  max-width: 420px;
}

.footer-col {
  display: flex;
  flex-direction: column;
}

.footer-col a {
  color: var(--muted);
  margin-bottom: 12px;
  transition: .3s ease;
}

.footer-col a:hover {
  color: var(--cyan);
  transform: translateX(4px);
}

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 22px 0;
  text-align: center;
  color: var(--muted);
  font-size: 14px;
}
.cta-section{
  padding-top: 30px;
  padding-bottom: 80px;
}

.cta-card{
  text-align:center;
  padding:70px 40px;

  border:1px solid var(--line);
  border-radius:32px;

  background:
    radial-gradient(circle at top,
      rgba(104,247,255,.12),
      transparent 55%),
    linear-gradient(
      145deg,
      rgba(255,255,255,.09),
      rgba(255,255,255,.03)
    );

  box-shadow:
    0 25px 70px rgba(0,0,0,.3);
}

.cta-card h2{
  max-width:900px;
  margin:15px auto 25px;
}

.cta-card p{
  max-width:750px;
  margin:0 auto;
}

.cta-actions{
  display:flex;
  justify-content:center;
  gap:16px;
  margin-top:35px;
  flex-wrap:wrap;
}
.logo{
    display:flex;
    align-items:center;
    gap:2px;
    font-size:42px;
    font-weight:900;
    letter-spacing:-0.08em;
    line-height:1;
}

.logo-m{
    color:#ffffff;
}

.logo-k{
    background:linear-gradient(
        135deg,
        #68f7ff,
        #7a7cff,
        #a56bff
    );
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

.logo-dot{
    width:8px;
    height:8px;
    border-radius:50%;
    background:#68f7ff;
    box-shadow:0 0 10px #68f7ff;
    margin-top:18px;
}

.logo:hover{
    transform:translateY(-1px);
}

.logo{
    transition:all .4s ease;
}
.logo{
  transition:.4s ease;
}

.logo:hover{
  transform:scale(1.05);
  filter:drop-shadow(
    0 0 12px rgba(104,247,255,.35)
  );
}
.footer-logo {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 18px;
}

.footer-logo.logo {
  font-size: 42px;
}
.hero-name{
    color:#ffffff;
    text-shadow:0 0 25px rgba(255,255,255,.08);
}

.hero-name .accent{
    color:#68f7ff;
    text-shadow:
        0 0 10px rgba(104,247,255,.4),
        0 0 20px rgba(104,247,255,.2);
}
.skill-card{
    transition:
        transform 0.5s ease,
        box-shadow 0.5s ease,
        border-color 0.5s ease;
}

.skill-card:hover{
    transform: translateY(-8px) scale(1.03);
    border-color: rgba(104,247,255,.45);

    box-shadow:
        0 20px 50px rgba(0,0,0,.35),
        0 0 25px rgba(104,247,255,.12);
}
.project-card{
    transition:
        transform .8s cubic-bezier(.22,1,.36,1),
        box-shadow .8s cubic-bezier(.22,1,.36,1),
        border-color .8s ease;
}

.project-card:hover{
    transform: translateY(-8px) scale(1.02);

    border-color: rgba(104,247,255,.45);

    box-shadow:
        0 25px 60px rgba(0,0,0,.35),
        0 0 25px rgba(104,247,255,.10);
}
.project-media img{
    transition:
        transform 1s cubic-bezier(.22,1,.36,1);
}

.project-card:hover .project-media img{
    transform: scale(1.04);
}


/* =========================================================
   FINAL POLISH / CLEAN OVERRIDES
   These rules intentionally stay at the end of the file.
   ========================================================= */

/* Header logo */
.logo {
  display: flex;
  align-items: center;
  gap: 2px;
  font-size: 42px;
  font-weight: 900;
  letter-spacing: -0.08em;
  line-height: 1;
  transition: transform .4s ease, filter .4s ease;
}

.logo:hover {
  transform: scale(1.05);
  filter: drop-shadow(0 0 12px rgba(104,247,255,.35));
}

.logo-m {
  color: #ffffff;
}

.logo-k {
  background: linear-gradient(135deg, #68f7ff, #7a7cff, #a56bff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.logo-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #68f7ff;
  box-shadow: 0 0 10px #68f7ff;
  margin-top: 18px;
}

.footer-logo {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 18px;
  font-size: 42px;
}

/* Hero name readability */
.hero-name {
  color: #ffffff;
  text-shadow: 0 0 25px rgba(255,255,255,.08);
}

.hero-name .accent {
  color: #68f7ff;
  text-shadow:
    0 0 10px rgba(104,247,255,.4),
    0 0 20px rgba(104,247,255,.2);
}

/* Project cards hover */
.project-card {
  position: relative;
  transform-origin: center;
  transition:
    transform .8s cubic-bezier(.22,1,.36,1),
    box-shadow .8s cubic-bezier(.22,1,.36,1),
    border-color .8s ease,
    filter .8s ease !important;
  will-change: transform;
}

.project-card:hover {
  transform: translateY(-8px) scale(1.02) !important;
  border-color: rgba(104,247,255,.45) !important;
  box-shadow:
    0 25px 60px rgba(0,0,0,.35),
    0 0 25px rgba(104,247,255,.10) !important;
  z-index: 10;
}

.project-media img {
  transition: transform 1s cubic-bezier(.22,1,.36,1), filter 1s ease;
}

.project-card:hover .project-media img {
  transform: scale(1.04);
  filter: brightness(1.04);
}

/* Skill cards hover */
.skill-card {
  transition:
    transform .7s cubic-bezier(.22,1,.36,1),
    box-shadow .7s cubic-bezier(.22,1,.36,1),
    border-color .7s ease !important;
}

.skill-card:hover {
  transform: translateY(-6px) scale(1.02) !important;
  border-color: rgba(104,247,255,.35) !important;
  box-shadow:
    0 15px 40px rgba(0,0,0,.28),
    0 0 18px rgba(104,247,255,.08) !important;
}

/* Project filters */
.project-card.hidden {
  display: none !important;
}

/* CTA */
.cta-section {
  padding-top: 30px;
  padding-bottom: 80px;
}

.cta-card {
  text-align: center;
  padding: 70px 40px;
  border: 1px solid var(--line);
  border-radius: 32px;
  background:
    radial-gradient(circle at top, rgba(104,247,255,.12), transparent 55%),
    linear-gradient(145deg, rgba(255,255,255,.09), rgba(255,255,255,.03));
  box-shadow: 0 25px 70px rgba(0,0,0,.3);
}

.cta-card h2 {
  max-width: 900px;
  margin: 15px auto 25px;
}

.cta-card p {
  max-width: 750px;
  margin: 0 auto;
}

.cta-actions {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-top: 35px;
  flex-wrap: wrap;
}

/* Footer responsiveness */
@media(max-width: 860px) {
  .footer-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}

/* =========================================================
   FINAL MOBILE GALLERY + BACK TO TOP FIX
   Screenshots match video width on mobile.
   Back-to-top button is disabled on touch/mobile devices.
   ========================================================= */

@media (max-width: 900px), (hover: none) and (pointer: coarse) {
  #backToTop,
  #backToTop.show {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}

@media (max-width: 768px) {
  .screenshots-slider {
    margin-top: 22px;
    padding: 14px 0 38px;
    overflow: visible;
  }

  .screenshots-track {
    gap: 18px;
    padding: 18px 4vw;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
  }

  .screenshots-track img {
    width: 92vw !important;
    min-width: 92vw !important;
    flex: 0 0 92vw !important;
    height: 51.75vw !important;
    min-height: 51.75vw !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 24px;
    scroll-snap-align: center;
    opacity: 1 !important;
    max-width: none !important;
  }

  .screenshots-track:hover img,
  .screenshots-track img:hover {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }

  .slider-btn {
    top: 50%;
    width: 54px;
    height: 54px;
    font-size: 36px;
    background: rgba(5,10,22,.78);
    border-color: rgba(104,247,255,.32);
    box-shadow: 0 10px 30px rgba(0,0,0,.36);
  }

  .slider-btn.prev {
    left: 10px;
  }

  .slider-btn.next {
    right: 10px;
  }

  .lightbox {
    padding: 18px;
  }

  .lightbox img {
    max-width: 100%;
    max-height: 82vh;
    border-radius: 16px;
  }

  .lightbox-nav {
    width: 54px;
    height: 54px;
    font-size: 26px;
    background: rgba(5,10,22,.72);
    border-color: rgba(104,247,255,.25);
  }

  .prev-img {
    left: 12px;
  }

  .next-img {
    right: 12px;
  }

  .lightbox-close {
    top: 14px;
    right: 20px;
    font-size: 38px;
  }
}

@media (max-width: 420px) {
  .screenshots-track img {
    width: 92vw !important;
    min-width: 92vw !important;
    flex-basis: 92vw !important;
    height: 51.75vw !important;
    min-height: 51.75vw !important;
  }

  .slider-btn {
    width: 50px;
    height: 50px;
  }

  .slider-btn.prev {
    left: 8px;
  }

  .slider-btn.next {
    right: 8px;
  }
}

/* =========================================================
   FINAL MOBILE CONTACT / EMAIL FIX
   Prevents email from overflowing outside the contact card.
   ========================================================= */

@media (max-width: 768px) {
  .contact-card {
    width: 100%;
    max-width: 100%;
    padding-left: 20px !important;
    padding-right: 20px !important;
    overflow: hidden;
  }

  .email-link {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box;
    font-size: clamp(18px, 5.1vw, 24px) !important;
    line-height: 1.25 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    text-align: center;
  }
}

@media (max-width: 420px) {
  .email-link {
    font-size: 19px !important;
    letter-spacing: -0.02em;
  }
}

@media (max-width: 360px) {
  .email-link {
    font-size: 17px !important;
  }
}

/* =========================================================
   FINAL MOBILE HERO TOP SPACING FIX
   Prevents the first hero card from being clipped by the fixed header.
   ========================================================= */

html {
  scroll-padding-top: 96px;
}

.section {
  scroll-margin-top: 96px;
}

@media (max-width: 768px) {
  html {
    scroll-padding-top: 112px;
  }

  .section {
    scroll-margin-top: 112px;
  }

  .hero {
    padding-top: 142px !important;
    align-items: flex-start;
  }

  .hero-grid {
    gap: 42px;
  }

  .hero-card:first-child {
    margin-top: 0;
  }
}

@media (max-width: 420px) {
  .hero {
    padding-top: 136px !important;
  }
}

/* =========================================================
   FINAL CONTENT / CONTACT POLISH
   ========================================================= */

.contact-actions {
  display: flex;
  justify-content: center;
  margin: 24px 0 10px;
}

.email-cta {
  min-width: 160px;
}

.email-link {
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 900px), (hover: none) and (pointer: coarse) {
  #backToTop,
  #backToTop.show {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}

@media (max-width: 768px) {
  .contact-actions {
    margin-top: 22px;
    margin-bottom: 12px;
  }

  .email-link {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    font-size: clamp(16px, 4.6vw, 20px) !important;
    line-height: 1.25 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
    text-align: center;
    margin-top: 10px;
  }

  .social-links a {
    font-size: 18px;
  }
}

@media (max-width: 380px) {
  .email-link {
    font-size: 15px !important;
  }
}

/* =========================================================
   FINAL CONTACT ICONS + MOBILE EMAIL BUTTON
   Desktop: shows button + email.
   Mobile: shows Email Me button, hides long email text.
   ========================================================= */

.contact-actions {
  display: flex;
  justify-content: center;
  margin: 24px 0 10px;
}

.email-cta {
  min-width: 160px;
  gap: 8px;
}

.contact-icon,
.social-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.contact-social-links a,
.social-links a {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.social-icon {
  font-size: 15px;
  opacity: .95;
  transform: translateY(-1px);
}

.email-link {
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 900px), (hover: none) and (pointer: coarse) {
  #backToTop,
  #backToTop.show {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }
}

@media (max-width: 768px) {
  .contact-actions {
    margin-top: 24px;
    margin-bottom: 24px;
  }

  .email-cta {
    min-width: 190px;
    padding: 16px 24px;
    font-size: 18px;
  }

  .contact-section .email-link {
    display: none !important;
  }

  .contact-social-links,
  .social-links {
    gap: 14px;
  }

  .contact-social-links a,
  .social-links a {
    font-size: 18px;
    gap: 8px;
  }

  .social-icon {
    font-size: 16px;
  }
}

