@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=JetBrains+Mono:wght@400;500;700&family=DM+Sans:ital,wght@0,400;0,500;0,600;1,400&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --c1:#00f5ff;--c2:#bf5fff;--c3:#ff2d78;--c4:#39ff14;--c5:#ff9500;
  --bg:#060b14;--bg2:#0b1423;--bg3:#0f1c30;
  --glass:rgba(255,255,255,0.04);--glass-b:rgba(255,255,255,0.08);
  --txt:#e2eeff;--txt2:#7a9bbf;--txt3:#4a6a8a;
  --font:'Outfit',sans-serif;--mono:'JetBrains Mono',monospace;
  --tag-font:'DM Sans',sans-serif;
  --r:12px;--r2:20px;
}

img{max-width:100%;height:auto;display:block}
.logo-img,
.nav-icon img,
.social-link img,
.am-icon img,
.tl-co img,
.bc-logo img,
.cert-illo img{
  height:clamp(28px,4vw,48px) !important;
  width:auto !important;
  object-fit:contain;
  background:transparent !important;
  padding:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  display:block;
}

.nav-icon{display:inline-flex;align-items:center;justify-content:center;padding:0;margin:0;min-width:0;background:transparent;border:none;height:auto}
html{scroll-behavior:smooth;overflow-x:hidden}
body{background:var(--bg);color:var(--txt);font-family:var(--font);overflow-x:hidden;cursor:none}
#cursor{position:fixed;width:12px;height:12px;background:var(--c1);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s;box-shadow:0 0 15px var(--c1)}
#cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid rgba(0,245,255,0.4);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all .12s ease}
#progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--c1),var(--c2),var(--c3));z-index:1000;width:0%;box-shadow:0 0 8px var(--c1)}
#bgCanvas{position:fixed;inset:0;z-index:0;opacity:.45}
.blob{position:fixed;border-radius:50%;filter:blur(100px);pointer-events:none;z-index:0;opacity:.25}
.blob1{width:500px;height:500px;background:radial-gradient(circle,rgba(0,245,255,0.4),transparent 70%);top:-150px;right:-100px;animation:blobMove 12s ease-in-out infinite}
.blob2{width:400px;height:400px;background:radial-gradient(circle,rgba(191,95,255,0.35),transparent 70%);bottom:20%;left:-100px;animation:blobMove 15s ease-in-out infinite reverse}
.blob3{width:300px;height:300px;background:radial-gradient(circle,rgba(255,45,120,0.3),transparent 70%);bottom:-100px;right:30%;animation:blobMove 10s ease-in-out infinite 3s}
@keyframes blobMove{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-30px) scale(1.05)}66%{transform:translate(-20px,20px) scale(.95)}}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:0 12.5%;height:68px;display:flex;align-items:center;gap:16px;backdrop-filter:blur(20px);background:rgba(6,11,20,0.8);border-bottom:1px solid rgba(255,255,255,0.06)}
.nav-logo{font-weight:800;font-size:21px;background:linear-gradient(135deg,var(--c1),var(--c2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px;text-decoration:none;white-space:nowrap}
.nav-links{display:flex;gap:26px;list-style:none;align-items:center;flex:1;justify-content:center}
.nav-links a{color:var(--txt2);text-decoration:none;font-size:13.5px;font-weight:500;transition:color .2s;position:relative}
.nav-links a:after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1px;background:var(--c1);transform:scaleX(0);transition:transform .3s}
.nav-links a:hover{color:var(--c1)}
.nav-links a:hover:after{transform:scaleX(1)}
.nav-icons{display:flex;gap:8px;align-items:center;margin-left:auto}
.nav-icon{display:inline-flex;align-items:center;justify-content:center;padding:0;margin:0;min-width:0;background:transparent;border:none;height:auto;color:var(--txt2);text-decoration:none;transition:all .18s}
.nav-icon:hover{transform:translateY(-3px);color:var(--c1)}
.nav-icon svg{width:17px;height:17px}
.nav-cta{padding:8px 20px;border-radius:50px;background:linear-gradient(135deg,var(--c1),var(--c2));color:#060b14;font-weight:700;font-size:13px;text-decoration:none;transition:all .2s;box-shadow:0 0 18px rgba(0,245,255,0.25);white-space:nowrap}

/* HERO */
#hero{min-height:auto;display:flex;align-items:center;padding:40px 12.5% 0;position:relative;z-index:1}
.hero-wrap{display:grid;grid-template-columns:1fr;justify-items:center;width:100%;max-width:100%;margin:0 auto;text-align:center}
.hero-wrap > div{width:min(100%,860px)}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:0;background:rgba(0,245,255,0.08);border:1px solid rgba(0,245,255,0.2);font-size:12.5px;font-family:var(--tag-font);font-weight:600;letter-spacing:.5px;color:var(--c1);margin-bottom:28px;animation:fadeUp .8s .1s both;white-space:nowrap}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--c4);box-shadow:0 0 8px var(--c4);animation:pulse 2s infinite}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;animation:fadeUp .8s .5s both}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.3)}}
h1.hero-name{font-size:clamp(50px,7vw,100px);font-weight:900;line-height:.92;letter-spacing:-3px;margin:56px 0 18px;animation:fadeUp .8s .2s both}
.line1{display:block;color:var(--txt)}
.line2{display:block;background:linear-gradient(135deg,var(--c1) 0%,var(--c2) 50%,var(--c3) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-typed-wrap{font-family:var(--mono);font-size:17px;color:var(--c2);margin-bottom:22px;animation:fadeUp .8s .3s both;min-height:22px}
.hero-typed-wrap .prefix{color:var(--txt3)}
.hero-cursor-t{display:inline-block;width:2px;height:15px;background:var(--c1);margin-left:3px;vertical-align:middle;animation:blink 1s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-bio{font-size:16px;line-height:1.85;color:var(--txt2);max-width:620px;margin-bottom:32px;animation:fadeUp .8s .4s both}
.hero-bio strong{color:var(--txt)}
.btn-primary{padding:13px 30px;border-radius:50px;background:linear-gradient(135deg,var(--c1),var(--c2));color:#060b14;font-weight:700;font-size:14px;text-decoration:none;transition:all .3s;box-shadow:0 4px 28px rgba(0,245,255,0.22)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 38px rgba(0,245,255,0.38)}
.btn-outline{padding:13px 30px;border-radius:50px;border:1px solid rgba(0,245,255,0.3);color:var(--c1);font-weight:600;font-size:14px;text-decoration:none;transition:all .3s}
.btn-outline:hover{background:rgba(0,245,255,0.07);border-color:var(--c1);transform:translateY(-3px)}
.hero-social{display:flex;gap:12px;margin-top:26px;animation:fadeUp .8s .6s both;flex-wrap:wrap;align-items:center}
.social-link{display:inline-flex;align-items:center;gap:0;padding:0;border-radius:0;border:none;background:transparent;color:var(--txt2);text-decoration:none;font-size:12px;font-weight:600;transition:transform .18s}
.social-link img{height:clamp(28px,4vw,48px);width:auto;display:block}
.social-link:hover{transform:translateY(-3px);color:var(--c1)}
.connect-links{display:flex;justify-content:center;gap:28px;flex-wrap:wrap;margin-top:20px}
.connect-link{display:inline-flex;align-items:center;justify-content:center;padding:8px;background:transparent;border:none;transition:transform .2s}
.connect-link img{width:auto;height:56px;max-height:56px;object-fit:contain}
.connect-link:hover{transform:translateY(-4px)}

@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeLeft{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* SECTIONS — 75% centered, consistent across the whole page */
.section,.section-centered{padding:48px 0 36px;position:relative;z-index:1;width:75%;max-width:1200px;margin:0 auto}
.sec-label{display:inline-flex;align-items:center;gap:10px;font-family:var(--mono);font-size:13px;color:var(--c1);letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.sec-label::before{content:'';width:28px;height:1px;background:linear-gradient(90deg,var(--c1),transparent)}
.sec-label::after{content:'';width:28px;height:1px;background:linear-gradient(270deg,var(--c1),transparent)}
.sec-title{font-size:clamp(38px,5vw,62px);font-weight:900;letter-spacing:-2px;margin-bottom:52px}
.sec-title span{background:linear-gradient(135deg,var(--c1),var(--c2));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .18s ease,transform .18s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* RECOGNITION — 4 in a single row */
.recognition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.rec-card{border-radius:var(--r2);padding:22px;background:var(--glass);border:1px solid var(--glass-b);transition:all .3s;display:flex;flex-direction:column;gap:10px;position:relative;overflow:hidden}
.rec-card:hover{transform:translateY(-6px);background:rgba(255,255,255,0.06)}
.rec-img-container{height:160px;display:flex;align-items:center;justify-content:center;border-radius:10px;margin-bottom:4px;overflow:hidden;background:rgba(255,255,255,0.02)}
.rec-img-container img{width:100%;height:100%;object-fit:contain;display:block}
.rec-img-container.clickable-image{cursor:pointer;transition:transform .2s}
.rec-img-container.clickable-image:hover{transform:scale(1.05)}
.rec-title{font-size:15px;font-weight:800;color:var(--txt)}
.rec-sub{font-size:12.5px;color:var(--txt2);line-height:1.7}
.carousel-btn-sm{width:28px;height:28px;border:none;border-radius:999px;background:rgba(255,255,255,0.1);color:var(--txt);cursor:pointer;transition:all .2s;font-size:14px;line-height:1;padding:0}
.carousel-btn-sm:hover{background:rgba(0,245,255,0.18);color:var(--c1)}
.carousel-counter{display:inline-block;margin-left:6px}
.carousel-nav{display:flex;gap:8px}
#imageModal{display:none;position:fixed;z-index:2000;inset:0;background:rgba(0,0,0,0.95);align-items:center;justify-content:center;backdrop-filter:blur(8px)}
#imageModal.open{display:flex}
.modal-content{position:relative;max-width:90vw;max-height:90vh;display:flex;align-items:center;justify-content:center;width:auto;padding:0 12px}
.modal-content img{max-width:80vw;max-height:80vh;object-fit:contain}
.modal-close{position:absolute;top:18px;right:18px;font-size:28px;color:#fff;cursor:pointer;background:rgba(0,0,0,0.85);border:1px solid rgba(255,255,255,0.35);z-index:2001;transition:all .2s;padding:10px 12px;border-radius:14px;display:flex;align-items:center;justify-content:center;width:46px;height:46px}
.modal-close:hover{color:var(--c1);background:rgba(0,0,0,0.95)}
.modal-content.small img{max-width:80vw;max-height:80vh}
@media(max-width:720px){
  .modal-content{max-width:95vw;max-height:95vh;padding:0 10px}
  .modal-content img{max-width:95vw;max-height:95vh}
  .modal-content.small img{max-width:95vw;max-height:95vh}
}
@media(max-width:900px){.recognition-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.recognition-grid{grid-template-columns:1fr}}

/* ABOUT — toggle view */
.about-header{display:flex;align-items:center;margin-bottom:40px;flex-wrap:wrap;gap:12px}
.about-toggle-text{
  display:inline;
  cursor:pointer;
  background:linear-gradient(135deg,var(--c1),var(--c2));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  transition:opacity .2s,color .2s;
  white-space:nowrap;
  text-decoration:none;
}
.about-toggle-text:hover{
  opacity:.85;
  color:#cbd5f7;
  -webkit-text-fill-color:initial;
  text-shadow:0 0 8px rgba(0,0,0,0.15);
}

/* Download Resume Link */
.download-resume-link{
  display:inline;
  margin-left:220px;
  font-size:clamp(22px,3vw,38px);
  background:linear-gradient(135deg,var(--c4),var(--c1));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  text-decoration:none;
  padding:0;
  border-radius:0;
  transition:all .2s ease;
  white-space:nowrap;
  font-weight:900;
  border:none;
  letter-spacing:-0.5px;
}
.download-resume-link:hover{
  opacity:0.85;
  text-shadow:0 0 8px rgba(57,255,20,0.3);
}
@media(max-width:768px){
  .download-resume-link{
    display:inline;
    margin-left:150px;
    font-size:clamp(16px,2.5vw,28px);
    padding:0;
  }
}
@media(max-width:480px){
  .download-resume-link{
    display:inline;
    margin-left:100px;
    font-size:clamp(14px,2vw,20px);
    padding:0;
  }
}

.about-availability{
  margin-top:46px;
  font-size:14px;
  font-weight:700;
  color:var(--c1);
  letter-spacing:.8px;
}

/* Detailed view  */
.about-detail-view{max-width:100%;margin:0 auto}
.about-text-centered{font-size:16px;line-height:1.95;color:var(--txt2);text-align:left}
.about-text-centered p{margin-bottom:20px}
.about-text-centered strong{color:var(--txt)}

/* Quick view  */
.about-quick-view{animation:fadeIn .35s ease both}
.about-cards-center{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  width:100%;
  align-items:stretch;
}
.about-card-large{
  background:var(--glass);
  border:1px solid var(--glass-b);
  border-radius:var(--r2);
  padding:26px 22px;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:14px;
  transition:all .3s;
  animation:fadeUp .4s ease both;
  min-height:280px;
  height:100%;
}
.about-card-large:hover{background:rgba(255,255,255,0.07);border-color:rgba(0,245,255,0.22);transform:translateY(-4px);box-shadow:0 10px 32px rgba(0,0,0,0.3)}
.about-card-large:nth-child(1){animation-delay:.05s;border-top:2px solid var(--c1)}
.about-card-large:nth-child(2){animation-delay:.1s;border-top:2px solid var(--c2)}
.about-card-large:nth-child(3){animation-delay:.15s;border-top:2px solid var(--c4)}
.about-card-large:nth-child(4){animation-delay:.2s;border-top:2px solid var(--c5)}
.acl-icon{flex-shrink:0;width:80px;height:80px;display:flex;align-items:center;justify-content:center}
.acl-icon img{height:80px;width:auto;object-fit:contain;display:block}
.acl-content{display:flex;flex-direction:column;gap:7px;min-width:0;width:100%;flex:1;justify-content:space-between}
.acl-title{font-size:15px;font-weight:800;color:var(--txt);margin-bottom:4px}
.acl-line{font-size:13px;color:var(--txt2);line-height:1.55;display:block}
.acl-highlight{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--c1);margin-top:6px;display:inline-block;white-space:nowrap}
.about-card-large:nth-child(2) .acl-highlight{color:var(--c2)}
.about-card-large:nth-child(3) .acl-highlight{color:var(--c4)}
.about-card-large:nth-child(4) .acl-highlight{color:var(--c5)}
@media(max-width:900px){.about-cards-center{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.about-cards-center{grid-template-columns:1fr}}

/* SKILLS */
.skills-tabs{display:flex;gap:9px;margin-bottom:36px;flex-wrap:wrap}
.tab-btn{padding:8px 20px;border-radius:50px;border:1px solid var(--glass-b);background:var(--glass);color:var(--txt2);font-size:13px;font-weight:600;cursor:pointer;transition:all .25s;font-family:var(--font)}
.tab-btn.active,.tab-btn:hover{background:linear-gradient(135deg,rgba(0,245,255,0.12),rgba(191,95,255,0.12));border-color:var(--c1);color:var(--c1)}
.skill-panel{display:none}
.skill-panel.active{display:block}
.skill-group{margin-bottom:30px}
.skill-group-title{font-size:19px;font-weight:800;color:var(--txt);margin-bottom:18px}
.skill-group-items{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:14px}
.skill-pill{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:22px 18px;
  border-radius:10px;
  background:var(--glass);
  border:1px solid var(--glass-b);
  transition:all .25s;
  cursor:default;
  min-height:72px;
}
.skill-pill:hover{transform:translateY(-5px);border-color:var(--c1);background:rgba(0,245,255,0.06);box-shadow:0 8px 28px rgba(0,245,255,0.12)}
.skill-pill .sp-icon{display:none}
.skill-pill .sp-name{
  font-size:16px;
  font-weight:700;
  color:var(--txt);
  text-align:center;
  font-family:var(--font);
}
@media(max-width:720px){.skill-group-items{grid-template-columns:repeat(2,1fr)}}

/* EXPERIENCE TIMELINE */
.timeline{position:relative;padding-left:30px}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(180deg,var(--c1),var(--c2),var(--c3),transparent)}
.tl-item{position:relative;margin-bottom:36px}
.tl-dot{position:absolute;left:-36px;top:24px;width:12px;height:12px;border-radius:50%;border:2px solid var(--c1);background:var(--bg);box-shadow:0 0 10px var(--c1)}
.tl-card{background:var(--glass);border:1px solid var(--glass-b);border-radius:var(--r2);padding:26px 30px;transition:all .3s}
.tl-card:hover{background:rgba(255,255,255,0.06);border-color:rgba(0,245,255,0.2);transform:translateX(5px)}
.tl-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:12px}
.tl-role{font-size:20px;font-weight:800;color:var(--txt)}
.tl-co{font-size:14.5px;font-family:var(--mono);margin-top:4px;display:flex;align-items:center;gap:8px}
.tl-period{padding:5px 13px;border-radius:50px;background:rgba(0,245,255,0.08);border:1px solid rgba(0,245,255,0.2);font-size:12px;color:var(--c1);font-family:var(--mono);white-space:nowrap;flex-shrink:0}
.tl-desc{list-style:none}
.tl-desc li{font-size:15px;color:var(--txt2);line-height:1.85;padding-left:20px;position:relative;margin-bottom:8px}
.tl-desc li::before{content:'▹';position:absolute;left:0;color:var(--c1);font-size:12px}
.tl-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}

.tl-tag,
.pc-tag{
  padding:4px 12px;
  border-radius:6px;
  font-size:11.5px;
  font-family:var(--tag-font);
  font-weight:600;
  letter-spacing:.2px;
}
.tl-tag{
  background:rgba(191,95,255,0.1);
  color:var(--c2);
  border:1px solid rgba(191,95,255,0.2);
}
.pc-tag{
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
  color:var(--txt2);
}

/* PROJECTS */
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:22px}
.proj-card{border-radius:var(--r2);background:var(--glass);border:1px solid var(--glass-b);overflow:hidden;transition:all .35s;position:relative}
.proj-card:hover{transform:translateY(-8px);box-shadow:0 20px 50px rgba(0,0,0,0.5)}
.proj-card:hover .pc-glow{opacity:1}
.pc-glow{position:absolute;inset:0;border-radius:var(--r2);pointer-events:none;opacity:0;transition:opacity .35s}
.pc-bar{height:3px;width:100%}
.pc-body{padding:24px 24px 0}
.pc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.pc-type{padding:4px 12px;border-radius:6px;font-size:11px;font-family:var(--tag-font);font-weight:700;letter-spacing:.2px}
.pc-link{width:33px;height:33px;border-radius:9px;background:rgba(255,255,255,0.05);border:1px solid var(--glass-b);display:flex;align-items:center;justify-content:center;color:var(--txt2);text-decoration:none;font-size:14px;transition:all .2s}
.pc-link:hover{color:var(--c1);border-color:var(--c1)}
.pc-illo{width:100%;height:120px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;border-radius:10px;overflow:hidden}
.pc-illo svg{width:100%;height:100%}
.pc-title{font-size:19px;font-weight:800;margin-bottom:10px}
.pc-desc{font-size:14.5px;color:var(--txt2);line-height:1.75;margin-bottom:18px}
.pc-tags{display:flex;flex-wrap:wrap;gap:6px;padding:0 24px 24px}

/* BUG BOUNTY */
.bounty-hero{padding:46px;border-radius:var(--r2);background:linear-gradient(135deg,rgba(255,149,0,0.05),rgba(255,45,120,0.05),rgba(191,95,255,0.05));border:1px solid rgba(255,149,0,0.14);margin-bottom:26px;display:flex;align-items:center;gap:46px;flex-wrap:wrap}
.bb-number{font-size:76px;font-weight:900;line-height:1;background:linear-gradient(135deg,var(--c5),var(--c3));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-4px}
.bb-text h3{font-size:24px;font-weight:800;margin-bottom:9px}
.bb-text p{font-size:14px;color:var(--txt2);line-height:1.8;max-width:480px}
.bounty-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}
.bounty-card{border-radius:var(--r2);padding:28px;border:1px solid rgba(255,255,255,0.07);background:var(--glass);transition:all .3s;position:relative;overflow:hidden}
.bounty-card:hover{transform:translateY(-6px);background:rgba(255,255,255,0.06)}
.bc-logo{margin-bottom:14px;display:flex;align-items:center;gap:10px}
.bc-logo img{height:36px;width:auto;object-fit:contain;background:transparent;border:none;box-shadow:none}
.bc-org{font-size:22px;font-weight:900;margin-bottom:5px;letter-spacing:-1px}
.bc-sub{font-size:11px;color:var(--txt3);font-family:var(--mono);margin-bottom:14px}
.bc-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 13px;border-radius:6px;font-size:11px;font-weight:700;font-family:var(--tag-font)}

/* CTF */
.ctf-card{border-radius:var(--r2);padding:28px 34px;background:linear-gradient(135deg,rgba(57,255,20,0.04),rgba(0,245,255,0.04));border:1px solid rgba(57,255,20,0.1);display:grid;grid-template-columns:auto 1fr auto;gap:28px;align-items:center}
.ctf-big{font-size:86px;font-weight:900;line-height:1;background:linear-gradient(135deg,var(--c4),var(--c1));-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-5px}
.ctf-big sup{font-size:32px}
.ctf-info h3{font-size:26px;font-weight:800;margin-bottom:8px}
.ctf-info p{font-size:15.5px;color:var(--txt2);line-height:1.8;max-width:420px;margin-bottom:18px}
.ctf-nums{display:flex;gap:24px;flex-wrap:wrap}
.ctf-n{display:flex;flex-direction:column;gap:3px}
.ctf-nv{font-size:22px;font-weight:800;color:var(--c4)}
.ctf-nl{font-size:11px;color:var(--txt3);font-family:var(--mono);letter-spacing:1px;text-transform:uppercase}
.ctf-illo{flex-shrink:0}
.ctf-illo svg,.ctf-illo img{width:250px;height:250px;object-fit:contain;display:block}
.ctf-illo.clickable-image{cursor:pointer;transition:transform .2s}
.ctf-illo.clickable-image:hover{transform:scale(1.04)}

/* CERTS */
.cert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.cert-card{border-radius:var(--r2);padding:26px;background:var(--glass);border:1px solid var(--glass-b);display:flex;flex-direction:column;gap:14px;transition:all .3s;overflow:hidden}
.cert-card:hover{transform:translateY(-5px);border-color:rgba(191,95,255,0.3);background:rgba(191,95,255,0.05)}
.cert-img-container{height:160px;display:flex;align-items:center;justify-content:center;border-radius:14px;overflow:hidden;background:rgba(255,255,255,0.04)}
.cert-img-container.clickable-image{cursor:pointer;transition:transform .2s}
.cert-img-container.clickable-image:hover{transform:scale(1.03)}
.cert-img-container img{width:100%;height:100%;object-fit:contain;display:block}
.cert-name{font-size:16px;font-weight:700;margin-bottom:4px}
.cert-issuer{font-size:13.5px;color:var(--txt2);font-family:var(--mono)}
.cert-year{font-size:12px;color:var(--c2);margin-top:4px;font-family:var(--mono)}

/* CONTACT */
.contact-wrap{display:grid;grid-template-columns:1fr;gap:54px;align-items:start;max-width:720px;margin:0 auto 56px}
.contact-text{text-align:center}
.contact-text h3{font-size:30px;font-weight:800;margin-bottom:16px}
.contact-text p{font-size:16px;color:var(--txt2);line-height:1.9;margin-bottom:28px}
.contact-links{display:flex;flex-direction:column;gap:16px}
.contact-link{
  display:flex;align-items:center;gap:18px;
  padding:18px 22px;border-radius:calc(var(--r) + 4px);
  background:var(--glass);border:1px solid var(--glass-b);
  text-decoration:none;color:var(--txt);transition:all .3s;
}
.contact-link:hover{border-color:var(--c1);background:rgba(0,245,255,0.08);transform:translateX(5px)}
.cl-bare-img{
  width:34px;height:auto;object-fit:contain;flex-shrink:0;
  display:block;background:transparent;
}
.cl-emoji-icon{
  font-size:24px;line-height:1;flex-shrink:0;display:block;
  width:34px;text-align:center;
}
.cl-icon{width:42px;height:42px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:22px}
.cl-label{font-size:12px;color:var(--txt3);font-family:var(--mono);margin-bottom:2px}
.cl-val{font-size:15px;font-weight:700}

/* FOOTER  */
.footer{
  position:relative;z-index:1;
  background:#020508;
  border-top:1px solid rgba(0,245,255,0.12);
  box-shadow:0 -4px 40px rgba(0,0,0,0.7),0 -1px 0 rgba(0,245,255,0.08);
  padding:56px 0;
  margin-top:24px;
  width:100%;
  max-width:none;
  box-sizing:border-box;
}
.footer-inner{display:grid;grid-template-columns:1fr auto 1fr;gap:48px;align-items:center;max-width:100%;margin:0;padding:0 24px}
.footer-brand{font-weight:800;font-size:26px;background:linear-gradient(135deg,var(--c1),var(--c2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:10px}
.footer-tagline{font-size:14px;color:var(--txt3);font-family:var(--mono)}
.footer-social{display:flex;gap:18px;justify-content:center;align-items:center}
.footer-icon-link{
  display:inline-flex;align-items:center;justify-content:center;
  padding:0;background:transparent;border:none;
  text-decoration:none;transition:transform .25s;
}
.footer-icon-link:hover{transform:translateY(-4px)}
.footer-bare-icon{
  height:34px;width:auto;object-fit:contain;
  display:block;background:transparent;
  opacity:.75;transition:opacity .2s;
}
.footer-icon-link:hover .footer-bare-icon{opacity:1}
.footer-emoji-icon{
  font-size:26px;line-height:1;display:block;
  opacity:.75;transition:opacity .2s;
}
.footer-icon-link:hover .footer-emoji-icon{opacity:1}
.footer-right{text-align:right;font-size:13px;color:var(--txt3);font-family:var(--mono);line-height:2.2}
.footer-right span{color:var(--c3)}

/* CONNECT section */
.connect-section{text-align:center}

@media(max-width:900px){
  .hero-wrap,.about-grid,.contact-wrap,.footer-inner{grid-template-columns:1fr}
  .hero-illo-wrap{display:none}
  .ctf-card{grid-template-columns:1fr;gap:20px}
  .ctf-illo{display:none}
  .ctf-big{font-size:64px}
  .bounty-hero{gap:22px;padding:28px}
  .bb-number{font-size:56px}
  .nav-links{display:none}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .footer-social{justify-content:center}
  .footer-right{text-align:center}
  .section,.section-centered{width:92%;padding:40px 0 28px}
}
