/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

:root{
  --bg:#f4f0eb;
  --bg-alt:#ece8e2;
  --ink:#0c0c0c;
  --ink2:#3a3a3a;
  --muted:#7a7670;
  --neon:#00e87a;
  --red:#e8002d;
  --blue:#0057ff;
  --card:#ffffff;
  --border:rgba(0,0,0,0.09);
  --border2:rgba(0,0,0,0.15);
  --shadow:0 4px 32px rgba(0,0,0,0.08);
  --shadow-lg:0 12px 48px rgba(0,0,0,0.14);
  --r:10px;
  --fd:'Bebas Neue',sans-serif;
  --fm:'Space Mono',monospace;
  --fb:'DM Sans',sans-serif;
}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--fb);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ===== TEXTURE ===== */
.noise{
  position:fixed;inset:0;z-index:9000;pointer-events:none;
  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");
  opacity:1;mix-blend-mode:multiply;
}

.halftone-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(0,0,0,0.055) 1px,transparent 1px);
  background-size:20px 20px;
}

/* ===== ABSTRACT SHAPES ===== */
.abstract-shapes{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.shape{position:absolute;border-radius:50%;opacity:0.04;}
.s1{width:600px;height:600px;background:var(--red);top:-200px;right:-200px;animation:drift 20s ease-in-out infinite alternate;}
.s2{width:400px;height:400px;background:var(--blue);bottom:-150px;left:-100px;animation:drift 25s ease-in-out infinite alternate-reverse;}
.s3{width:200px;height:200px;background:var(--neon);top:40%;left:60%;animation:drift 18s ease-in-out infinite alternate;}
.s4{
  width:300px;height:2px;background:var(--ink);
  top:30%;left:0;opacity:0.06;
  transform:rotate(-8deg);
  border-radius:0;
  animation:none;
}

/* Cross hatch pattern overlay */
.abstract-shapes::after{
  content:'';
  position:absolute;inset:0;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 39px,rgba(0,0,0,0.025) 39px,rgba(0,0,0,0.025) 40px),
    repeating-linear-gradient(90deg,transparent,transparent 39px,rgba(0,0,0,0.025) 39px,rgba(0,0,0,0.025) 40px);
  pointer-events:none;
}

@keyframes drift{from{transform:translate(0,0) scale(1);}to{transform:translate(30px,20px) scale(1.05);}}

/* ===== NAV ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 48px;
  background:rgba(244,240,235,0.88);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  transition:box-shadow 0.3s;
}
.nav.scrolled{box-shadow:0 2px 24px rgba(0,0,0,0.08);}
.nav-logo{
  font-family:var(--fm);font-size:0.85rem;letter-spacing:3px;
  color:var(--red);font-weight:700;
}
.nav-links{display:flex;gap:36px;list-style:none;}
.nav-links a{
  font-family:var(--fm);font-size:0.7rem;letter-spacing:1.5px;
  text-decoration:none;color:var(--ink2);text-transform:uppercase;
  transition:color 0.2s;
}
.nav-links a:hover{color:var(--red);}
.nav-cta{
  background:var(--ink)!important;color:var(--bg)!important;
  padding:7px 18px!important;border-radius:3px;
}
.nav-cta:hover{background:var(--red)!important;color:#fff!important;}

.hamburger{
  display:none;background:none;border:none;cursor:pointer;
  flex-direction:column;gap:5px;padding:4px;
}
.hamburger span{
  display:block;width:24px;height:2px;background:var(--ink);
  transition:all 0.3s;border-radius:2px;
}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px);}

.mobile-menu{
  display:none;flex-direction:column;
  position:fixed;top:56px;left:0;right:0;z-index:999;
  background:var(--bg);border-bottom:2px solid var(--red);
  padding:24px;gap:0;
  width:100%;
  overflow-x:hidden;
}
.mobile-menu.open{display:flex;}
.mobile-menu a{
  font-family:var(--fm);font-size:0.9rem;text-decoration:none;
  color:var(--ink);padding:14px 0;border-bottom:1px solid var(--border);
  letter-spacing:1px;
}

/* ===== HERO ===== */
.hero{
  min-height:100vh;padding:120px 48px 80px;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  align-items:center;position:relative;z-index:1;
}

.hero-status{
  display:flex;align-items:center;gap:10px;margin-bottom:20px;
  font-family:var(--fm);font-size:0.68rem;letter-spacing:2px;color:var(--muted);
}
.status-dot{
  width:8px;height:8px;background:var(--neon);border-radius:50%;
  box-shadow:0 0 8px var(--neon);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{box-shadow:0 0 8px var(--neon);}50%{box-shadow:0 0 16px var(--neon),0 0 24px rgba(0,232,122,0.3);}}

.hero-title{
  font-family:var(--fd);
  font-size:clamp(5rem,9vw,10rem);
  line-height:0.88;letter-spacing:-1px;margin-bottom:24px;
}
.neon-stroke{
  -webkit-text-stroke:3px var(--red);
  color:transparent;
  display:block;
}

.hero-descriptor{
  font-family:var(--fm);font-size:0.75rem;letter-spacing:2px;
  color:var(--red);margin-bottom:16px;text-transform:uppercase;
}

.hero-sub{
  font-size:0.95rem;line-height:1.75;color:var(--ink2);
  max-width:480px;margin-bottom:28px;
}

.hero-meta{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  margin-bottom:36px;
}
.meta-link{
  font-family:var(--fm);font-size:0.65rem;letter-spacing:1px;
  color:var(--muted);text-decoration:none;
}
.meta-link:hover{color:var(--red);}
.meta-sep{color:var(--border2);}

.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:24px;}

.btn-primary{
  font-family:var(--fm);font-size:0.75rem;letter-spacing:1px;
  text-decoration:none;background:var(--ink);color:var(--card);
  padding:14px 32px;border-radius:3px;display:inline-block;
  transition:transform 0.2s,box-shadow 0.2s,background 0.2s;
  border:2px solid var(--ink);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,0.18);background:var(--red);border-color:var(--red);}

.btn-outline{
  font-family:var(--fm);font-size:0.75rem;letter-spacing:1px;
  text-decoration:none;border:2px solid var(--ink);color:var(--ink);
  padding:12px 32px;border-radius:3px;display:inline-block;
  transition:all 0.2s;
}
.btn-outline:hover{background:var(--ink);color:var(--bg);}

.hero-links{display:flex;gap:24px;}
.social-link{
    display:flex;align-items:center;gap:6px;
  font-family:var(--fm);font-size:0.7rem;letter-spacing:1px;
  color:var(--muted);text-decoration:none;
  transition:color 0.2s;
}
.social-link:hover{color:var(--red);}

/* PHOTO */
.hero-right{display:flex;flex-direction:column;gap:0;align-items:center;width:100%;max-width:400px;justify-self:center;}

.photo-frame{
  position:relative;width:100%;max-width:400px;
  aspect-ratio:3/4;justify-self:center;align-self:start;
}

.photo-wrap{
  width:100%;height:100%;border-radius:6px 6px 0 0;overflow:hidden;
  position:relative;
}
.photo-wrap img{
  width:100%;height:100%;object-fit:cover;
  display:block;
  filter:contrast(1.05) saturate(0.95);
}
.photo-wrap.no-photo img{display:none;}
.photo-wrap.no-photo{
  background:linear-gradient(145deg,#e4ddd4 0%,#cdc6bc 100%);
  display:flex;align-items:center;justify-content:center;
}

.photo-fallback{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:12px;
  pointer-events:none;
}
.photo-wrap:not(.no-photo) .photo-fallback{display:none;}
.fallback-initials{
  font-family:var(--fd);font-size:5rem;color:var(--muted);opacity:0.5;
}
.fallback-hint{
  font-family:var(--fm);font-size:0.6rem;color:var(--muted);
  letter-spacing:2px;opacity:0.7;
}

.corner{
  position:absolute;width:20px;height:20px;
  border-color:var(--red);border-style:solid;
}
.corner.tl{top:-6px;left:-6px;border-width:2px 0 0 2px;}
.corner.tr{top:-6px;right:-6px;border-width:2px 2px 0 0;}
.corner.bl{bottom:-6px;left:-6px;border-width:0 0 2px 2px;}
.corner.br{bottom:-6px;right:-6px;border-width:0 2px 2px 0;}

.photo-label-tag{
  position:absolute;bottom:16px;right:-12px;
  font-family:var(--fm);font-size:0.55rem;letter-spacing:3px;
  background:var(--ink);color:var(--card);
  padding:6px 12px;border-radius:2px;
  writing-mode:vertical-rl;
  text-orientation:mixed;
  transform:rotate(180deg);
}

/* HERO STATS */
.hero-stats{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:var(--border2);
  
  border-radius:var(--r);  /* replace the current border-radius line */
  overflow:hidden;
  width:100%;
  margin-top:16px;
}
.stat{
  background:var(--card);padding:20px 16px;text-align:center;
}
.stat-num{
  display:block;font-family:var(--fd);font-size:2rem;
  color:var(--ink);margin-bottom:4px;
}
.stat-label{
  display:block;font-family:var(--fm);font-size:0.55rem;
  letter-spacing:1px;color:var(--muted);text-transform:uppercase;
}

/* ===== MARQUEE ===== */
.marquee-wrap{
  overflow:hidden;background:var(--ink);padding:14px 0;
  position:relative;z-index:1;
  border-top:2px solid var(--red);border-bottom:2px solid var(--red);
}
.marquee-track{
  display:flex;gap:28px;white-space:nowrap;
  animation:marquee 22s linear infinite;
  font-family:var(--fd);font-size:0.95rem;letter-spacing:3px;
  color:#ffffff;
}
.marquee-track .dot{color:var(--red);}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ===== SECTIONS ===== */
.section{padding:100px 48px;position:relative;z-index:1;}
.alt-bg{background:var(--bg-alt);}

.section-header{
  display:flex;align-items:center;gap:16px;
  margin-bottom:56px;flex-wrap:nowrap;
}
.section-tag{
  font-family:var(--fm);font-size:0.75rem;color:var(--red);letter-spacing:2px;
  position:relative;top:4px;
}
.section-tag{
  font-family:var(--fm);font-size:0.75rem;color:var(--red);letter-spacing:2px;
}
.section-title{
  font-family:var(--fd);font-size:clamp(2.5rem,5vw,4.5rem);
  letter-spacing:-1px;line-height:1;
}

/* TOGGLE */
.toggle-wrap{
  margin-left:auto;display:flex;gap:0;
  border:1.5px solid var(--border2);border-radius:4px;overflow:hidden;
  align-self:center;
}   
.toggle-btn{
  font-family:var(--fm);font-size:0.7rem;letter-spacing:2px;
  padding:8px 20px;border:none;cursor:pointer;
  background:transparent;color:var(--muted);
  text-transform:uppercase;transition:all 0.2s;
}
.toggle-btn:first-child{border-right:1px solid var(--border2);}
.toggle-btn.active{background:var(--ink);color:var(--card);}
.toggle-btn:not(.active):hover{background:var(--border);color:var(--ink);}

/* ===== TIMELINE ===== */
.timeline{
  position:relative;padding-left:32px;
}
.timeline::before{
  content:'';position:absolute;left:0;top:0;bottom:0;
  width:2px;background:var(--border2);
}

.timeline-item{
  position:relative;padding:0 0 56px 40px;
  transition:transform 0.3s;
  will-change:transform;
}
.timeline-item:hover{transform:translateX(6px);}
.timeline-item::before{
  content:'';position:absolute;
  left:-40px;top:6px;
  width:10px;height:10px;
  border-radius:50%;background:var(--bg);
  border:2px solid var(--red);
  z-index:2;
  transition:background 0.3s;
}
.timeline-item:hover::before{background:var(--red);}
.timeline-meta{
  display:flex;align-items:center;gap:12px;margin-bottom:12px;
}
.timeline-period{
  font-family:var(--fm);font-size:0.65rem;letter-spacing:1px;
  color:var(--muted);
}
.timeline-badge{
  font-family:var(--fm);font-size:0.55rem;letter-spacing:2px;
  padding:3px 10px;border-radius:2px;text-transform:uppercase;
}
.timeline-badge.upcoming{background:var(--ink);color:var(--card);}

.timeline-content h3{
  font-family:var(--fd);font-size:1.8rem;letter-spacing:-0.5px;
  margin-bottom:6px;
}
.timeline-org{
  display:block;font-family:var(--fm);font-size:0.7rem;
  letter-spacing:1px;color:var(--red);margin-bottom:12px;
}
.timeline-content p{
  font-size:0.9rem;line-height:1.7;color:var(--ink2);
}
.timeline-content ul{
  list-style:none;display:flex;flex-direction:column;gap:8px;
}
.timeline-content ul li{
  font-size:0.88rem;line-height:1.7;color:var(--ink2);
  padding-left:16px;position:relative;
}
.timeline-content ul li::before{
  content:'—';position:absolute;left:0;color:var(--red);
  font-family:var(--fm);
}

/* ===== PROJECTS ===== */
.projects-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));
  gap:24px;
  padding:16px;
  margin:-16px;
}
.projects-grid.hidden{display:none;}

.project-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:32px;
  position:relative;overflow:visible;
  transition:transform 0.3s,box-shadow 0.3s,border-color 0.2s;
  cursor:default;
  display:flex;flex-direction:column;
}
.project-card p{
  flex:1;
  font-size:0.875rem;line-height:1.7;color:var(--ink2);margin-bottom:20px;
}
.project-card .card-glow{overflow:hidden;}
.project-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
  border-color:var(--red);
}
.civil-card:hover{
  border-color:var(--red);
}



.card-eyebrow{
  display:flex;align-items:center;gap:12px;margin-bottom:14px;
}
.card-num{
  font-family:var(--fm);font-size:0.6rem;letter-spacing:3px;
  color:var(--red);
}
.civil-card .card-num
.card-type{
  font-family:var(--fm);font-size:0.6rem;letter-spacing:1px;
  color:var(--muted);
}

.project-card h3{
  font-family:var(--fd);font-size:1.9rem;letter-spacing:-0.3px;
  margin-bottom:12px;line-height:1;
}
.project-card p{
  font-size:0.875rem;line-height:1.7;color:var(--ink2);margin-bottom:20px;
}

.card-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}
.pill{
  font-family:var(--fm);font-size:0.6rem;letter-spacing:1px;
  background:var(--bg-alt);padding:4px 10px;border-radius:20px;
  border:1px solid var(--border);
}

.card-footer{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;flex-wrap:wrap;
  padding-top:16px;border-top:1px solid var(--border);
}
.card-metric{
  font-family:var(--fm);font-size:0.6rem;letter-spacing:1px;
  color:var(--muted);
}
.card-links{display:flex;gap:12px;}
.card-link{
  font-family:var(--fm);font-size:0.7rem;font-weight:700;
  color:var(--red);text-decoration:none;
  transition:opacity 0.2s;letter-spacing:0.5px;
}
.card-link:hover{opacity:0.7;}

.card-glow{
  position:absolute;bottom:-80px;right:-80px;
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(232,0,45,0.06) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.civil-card .card-glow{
  background:radial-gradient(circle,rgba(0,87,255,0.06) 0%,transparent 70%);
}

/* ===== SKILLS ===== */
.skills-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:32px;
}
.skill-group h4{
  font-family:var(--fm);font-size:0.7rem;letter-spacing:2px;
  color:var(--red);margin-bottom:16px;text-transform:uppercase;
}
.skill-tags{display:flex;flex-wrap:wrap;gap:8px;}
.skill-tags span{
  font-family:var(--fm);font-size:0.65rem;letter-spacing:0.5px;
  border:1px solid var(--border2);padding:6px 14px;border-radius:3px;
  color:var(--ink2);transition:all 0.2s;
}
.skill-tags span:hover{
  background:var(--ink);color:var(--card);border-color:var(--ink);
}

/* ===== ACHIEVEMENTS ===== */
.ach-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
}
.ach-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:28px;
  transition:transform 0.3s,box-shadow 0.3s;
  will-change:transform;
  position:relative;
}
.ach-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-lg),0 0 0 1px var(--red);
}
.ach-year{
  font-family:var(--fm);font-size:0.6rem;letter-spacing:3px;
  color:var(--red);margin-bottom:10px;
}
.ach-card h4{
  font-family:var(--fm);font-size:0.82rem;font-weight:700;
  margin-bottom:8px;line-height:1.4;
}
.ach-card p{
  font-size:0.83rem;line-height:1.6;color:var(--muted);
}

/* ===== CONNECT ===== */
.connect-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
}
.connect-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--r);padding:40px 36px;
  display:flex;flex-direction:column;gap:16px;
}
.resume-card{border-top:3px solid var(--red);}
.cookie-card{border-top:3px solid var(--card);}
.contact-card{border-top:3px solid var(--blue);}

.connect-label{
  font-family:var(--fm);font-size:0.6rem;letter-spacing:3px;
  color:var(--muted);text-transform:uppercase;
}
.connect-card h3{
  font-family:var(--fd);font-size:2rem;letter-spacing:-0.5px;
}
.connect-card p{
  font-size:0.875rem;line-height:1.7;color:var(--ink2);
}
.connect-note{
  font-family:var(--fm);font-size:0.6rem;color:var(--muted);
  letter-spacing:1px;margin-top:8px;
}
.contact-links{
  display:flex;flex-direction:column;gap:12px;margin-top:4px;
}
.contact-links a{
  font-family:var(--fm);font-size:0.72rem;letter-spacing:0.5px;
  color:var(--ink2);text-decoration:none;
  border-bottom:1px solid var(--border);padding-bottom:10px;
  transition:color 0.2s;
}
.contact-links a:hover{color:var(--red);}

/* ===== UPI ===== */
.upi-card{border-top:3px solid var(--card);}

.upi-id{
  display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  background:var(--bg-alt);border:1px solid var(--border2);
  border-radius:4px;padding:14px 18px;
  cursor:pointer;transition:background 0.2s,border-color 0.2s;
  user-select:none;
}
.upi-id:hover{background:var(--ink);border-color:var(--ink);}
.upi-id:hover #upiText{color:var(--card);}
.upi-id:hover .upi-copy-hint{color:rgba(255,255,255,0.4);}

#upiText{
  font-family:var(--fm);font-size:0.85rem;letter-spacing:1px;
  color:var(--ink);transition:color 0.2s;
  display:block;
}

.upi-copy-hint{
  font-family:var(--fm);font-size:0.58rem;letter-spacing:2px;
  color:var(--muted);text-transform:uppercase;
  transition:color 0.2s;
  display:block;
}
.upi-copied{
  display:none;
  color:var(--card)!important;
}

/* ===== FOOTER ===== */
.footer{
  background:var(--ink);padding:48px;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:24px;position:relative;z-index:1;
}
.footer-name{
  display:block;font-family:var(--fd);font-size:1.6rem;
  color:var(--card);letter-spacing:-0.5px;margin-bottom:4px;
}
.footer-sub{
  font-family:var(--fm);font-size:0.62rem;letter-spacing:1px;
  color:rgba(255,255,255,0.35);
}
.footer-right{display:flex;gap:28px;}
.footer-right a{
  font-family:var(--fm);font-size:0.7rem;letter-spacing:1px;
  color:rgba(255,255,255,0.5);text-decoration:none;
  transition:color 0.2s;
}
.footer-right a:hover{color:var(--card);}

/* ===== SCROLL ANIMATIONS ===== */
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.6s ease,transform 0.6s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}

/* ===== MOBILE ===== */
@media(max-width:900px){
    .hero-actions{justify-content:center;}
    .hero-links{justify-content:center;}
  .nav{padding:14px 24px;}
  .nav-links{display:none;}
  .hamburger{display:flex;}

.hero{
    grid-template-columns:1fr;padding:96px 24px 60px;
    text-align:left;gap:32px;
  }
  .hero-left{
    display:contents;
  }
.hero-title{order:1;font-size:clamp(5rem,18vw,9rem);
    text-align:center;letter-spacing:6px;word-spacing:14px;}
.neon-stroke{text-align:center;}
  .hero-right{
    order:2;
    align-items:center;
    width:100%;
  }
  .hero-status{order:3;}
  .hero-descriptor{order:4;}
  .hero-sub{order:5;max-width:100%;}
  .hero-meta{order:6;}
  .hero-actions{order:7;}
  .hero-links{order:8;}
  .photo-frame{max-width:300px;aspect-ratio:1/1;margin:0 auto;}
  .photo-label-tag{display:none;}
  .hero-stats{max-width:300px;}

  .section{padding:64px 24px;}
  .timeline{padding-left:20px;}
.timeline-item{padding-left:28px;transition:transform 0.3s;will-change:transform;}

  .projects-grid{grid-template-columns:1fr;}
  .connect-grid{grid-template-columns:1fr;}
  .skills-grid{grid-template-columns:1fr;}
  .ach-grid{grid-template-columns:1fr;isolation:isolate;}

  .section-header{gap:12px;}
  .toggle-wrap{margin-left:0;margin-top:0;align-self:center;}

  .footer{flex-direction:column;align-items:flex-start;padding:36px 24px;}
}

@media(max-width:480px){
.hero-title{font-size:clamp(3.8rem,16vw,5.5rem);letter-spacing:6px;word-spacing:14px;}
  .hero-stats{grid-template-columns:repeat(2,1fr);max-width:100%;}
  .stat-num{font-size:1.4rem;}
}
/* ===== SCROLL TO TOP ===== */
.scroll-top-btn{
  position:fixed;bottom:24px;right:24px;z-index:900;
  width:32px;height:32px;border-radius:3px;
  background:var(--ink);color:var(--card);
  border:none;cursor:pointer;
  font-family:var(--fm);font-size:0.75rem;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transform:translateY(8px);
  transition:opacity 0.3s,transform 0.3s;
}
.scroll-top-btn.visible{
  opacity:1;pointer-events:auto;
  transform:translateY(0);
}
.scroll-top-btn:hover{background:var(--red);}

@media(max-width:900px){
  .scroll-top-btn{
    right:25px;
    bottom:16px;
  }
}   

/* ===== OVERFLOW FIX ===== */
html, body{
  max-width:100%;
  overflow-x:hidden;
}

.marquee-wrap{
  overflow:hidden;
  width:100%;
  max-width:100%;
}

.marquee-track{
  width:max-content;
}