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

/* ─────────────────────────────────────────────────
   TOKENS
───────────────────────────────────────────────── */
:root {
  --bg:        #020204;
  --bg2:       #07070b;
  --surface:   rgba(255,255,255,0.02);
  --border:    rgba(255,255,255,0.06);
  --text:      #f8fafc;
  --muted:     #94a3b8;
  --accent:    #00f0ff;
  --accent2:   #7c3aed;
  --green:     #10b981;
  --a-rgb:     0,240,255;
  --grad:      linear-gradient(135deg, var(--accent), #8b5cf6, var(--accent2));
  --ease:      cubic-bezier(.4,0,.2,1);
  --max-w:     1140px;
}

/* ─────────────────────────────────────────────────
   RESET
───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',sans-serif;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Outfit',sans-serif;line-height:1.1}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{display:block;max-width:100%}
.mono{font-family:'JetBrains Mono',monospace;font-size:.82rem;color:var(--accent)}

/* ─────────────────────────────────────────────────
   UTILS
───────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}
.gradient-text{background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.glass{
  background:linear-gradient(135deg, rgba(255,255,255,0.03), rgba(255,255,255,0.005));
  border:1px solid var(--border);
  box-shadow: 0 8px 32px 0 rgba(0, 0, 0, 0.37);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-radius:1.25rem;
}
.label{
  font-size:.72rem;font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;color:var(--accent);margin-bottom:.75rem;display:block;
}
.section-header{margin-bottom:4rem}
.section-header h2{font-size:clamp(2rem,4vw,3rem);font-weight:800}

/* Reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.reveal.visible{opacity:1;transform:none}
.reveal-delay{transition-delay:.2s}

/* ─────────────────────────────────────────────────
   PAGE LOADER
───────────────────────────────────────────────── */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  transition:opacity .5s var(--ease),visibility .5s;
}
#loader.done{opacity:0;visibility:hidden}
.loader-inner{display:flex;flex-direction:column;align-items:center;gap:1.5rem}
.loader-logo{font-family:'Outfit',sans-serif;font-size:2.5rem;font-weight:900}
.loader-bar{width:160px;height:3px;background:var(--border);border-radius:3px;overflow:hidden}
.loader-fill{
  height:100%;width:0;
  background:var(--grad);
  border-radius:3px;
  transition:width 1.2s var(--ease);
}

/* ─────────────────────────────────────────────────
   CUSTOM CURSOR
───────────────────────────────────────────────── */
#cursor{
  width:36px;height:36px;
  border:1.5px solid rgba(var(--a-rgb),.5);
  border-radius:50%;
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:9000;
  transform:translate(-50%,-50%);
  transition:width .25s,height .25s,border-color .25s,background .25s;
}
#cursor-dot{
  width:5px;height:5px;
  background:var(--accent);
  border-radius:50%;
  position:fixed;top:0;left:0;
  pointer-events:none;z-index:9001;
  transform:translate(-50%,-50%);
}
body:has(a:hover) #cursor,
body:has(button:hover) #cursor{
  width:52px;height:52px;
  background:rgba(var(--a-rgb),.1);
  border-color:var(--accent);
}
@media(pointer:coarse){#cursor,#cursor-dot{display:none}}

/* ─────────────────────────────────────────────────
   GRAIN OVERLAY
───────────────────────────────────────────────── */
.grain{
  position:fixed;inset:0;z-index:1;
  pointer-events:none;
  opacity:.028;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
  background-repeat:repeat;
  background-size:200px;
}

/* ─────────────────────────────────────────────────
   INTERACTIVE BACKGROUND CANVAS
───────────────────────────────────────────────── */
#bg-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

/* ─────────────────────────────────────────────────
   BUTTONS
───────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.8rem 1.75rem;border-radius:.75rem;
  font-weight:600;font-size:.95rem;cursor:pointer;
  transition:all .25s var(--ease);border:none;
  font-family:'Inter',sans-serif;
}
.btn-sm{padding:.55rem 1.2rem;font-size:.85rem}
.btn-full{width:100%;justify-content:center}
.btn-primary{
  background:var(--grad);color:#fff;
  box-shadow:0 4px 20px rgba(var(--a-rgb),.35);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 8px 30px rgba(var(--a-rgb),.55)}
.btn-ghost{
  background:var(--surface);color:var(--text);
  border:1px solid var(--border);
}
.btn-ghost:hover{background:rgba(255,255,255,.08);transform:translateY(-3px)}
.dot{color:var(--accent)}

/* ─────────────────────────────────────────────────
   NAVBAR
───────────────────────────────────────────────── */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:800;
  padding:1.25rem 0;transition:all .35s var(--ease);
}
#navbar.scrolled{
  background:rgba(7,7,15,.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);padding:.85rem 0;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{font-family:'Outfit',sans-serif;font-size:1.4rem;font-weight:900}
.nav-links{display:flex;gap:2rem}
.nav-links a{color:var(--muted);font-size:.9rem;font-weight:500;transition:color .2s;position:relative}
.nav-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;
  background:var(--grad);border-radius:2px;
  transform:scaleX(0);transition:transform .25s var(--ease);
}
.nav-links a:hover,.nav-links a.active{color:var(--text)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-right{display:flex;align-items:center;gap:1rem}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}

/* ─────────────────────────────────────────────────
   HERO
───────────────────────────────────────────────── */
#hero{
  min-height:100vh;display:flex;flex-direction:column;
  justify-content:center;position:relative;overflow:hidden;
  padding:7rem 0 0;
}
.hero-bg{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:1;}
.grid-lines{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 40%,transparent 100%);
}

.hero-inner{
  display:grid;grid-template-columns:1fr auto;
  align-items:center;gap:4rem;
  position:relative;z-index:2;padding-bottom:3rem;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:.6rem;
  background:rgba(var(--a-rgb),.1);border:1px solid rgba(var(--a-rgb),.25);
  color:var(--accent);padding:.5rem 1rem;border-radius:2rem;
  font-size:.78rem;font-weight:600;letter-spacing:.05em;
  margin-bottom:1.5rem;
}
.pulse-dot{
  width:8px;height:8px;background:var(--green);border-radius:50%;
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{opacity:.7;box-shadow:0 0 0 6px rgba(34,197,94,0)}}

.hero-text h1{
  font-size:clamp(3rem,7vw,5.5rem);font-weight:900;
  margin-bottom:1.5rem;line-height:1.05;
}
.type-wrap{display:block;min-height:1.1em}
.cursor-blink{animation:blink .8s step-end infinite;color:var(--accent)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
.hero-sub{color:var(--muted);font-size:1.1rem;max-width:540px;line-height:1.8;margin-bottom:2.5rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2rem}
.hero-socials{display:flex;gap:.75rem}
.hero-socials a{
  width:40px;height:40px;display:flex;align-items:center;justify-content:center;
  border-radius:.6rem;background:var(--surface);border:1px solid var(--border);
  color:var(--muted);transition:all .25s;
}
.hero-socials a:hover{color:var(--text);border-color:var(--accent);transform:translateY(-2px)}

/* Hero card stack */
.hero-card-stack{
  position:relative;width:300px;height:380px;flex-shrink:0;
}
.avatar-ring{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);
  width:170px;height:170px;border-radius:50%;
  padding:3px;background:var(--grad);
  animation:spin-slow 10s linear infinite;
}
@keyframes spin-slow{to{transform:translate(-50%,-60%) rotate(360deg)}}
.avatar-inner{
  width:100%;height:100%;border-radius:50%;
  background:var(--bg2);
  display:flex;align-items:center;justify-content:center;
  font-family:'Outfit',sans-serif;font-size:2.8rem;font-weight:900;
  animation:spin-slow 10s linear infinite reverse;
  background:linear-gradient(135deg,var(--bg2),#1a1a2e);
}
.hero-card{
  position:absolute;display:flex;align-items:center;gap:.9rem;
  padding:.9rem 1.1rem;border-radius:1rem;font-size:.82rem;
  transition:transform .3s var(--ease);
  animation:float 4s ease-in-out infinite;
}
.hero-card:hover{transform:scale(1.04) translateY(-5px); border-color:rgba(var(--a-rgb),0.5); box-shadow: 0 10px 30px rgba(var(--a-rgb), 0.2);}
.hc-1{top:0;left:0;animation-delay:0s}
.hc-2{bottom:0;right:0;animation-delay:1.3s}
.hc-3{bottom:60px;left:-20px;animation-delay:.7s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hc-icon{font-size:1.5rem}
.hc-title{font-weight:700;font-size:.85rem}
.hc-sub{color:var(--muted);font-size:.75rem;margin-top:.15rem}

.hc-cert {
  position: absolute;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.85rem;
  box-shadow: 0 4px 15px rgba(0,0,0,0.3);
  animation: float 4s ease-in-out infinite;
  transition: transform 0.3s var(--ease);
  z-index: 10;
  cursor: default;
}
.hc-cert:hover {
  transform: scale(1.15) translateY(-5px);
  z-index: 20;
}
.hcc-1 { top: -5px; right: -5px; animation-delay: 0.5s; background: linear-gradient(135deg, #0055a4, #0072ce); color: white; border: 1px solid rgba(255,255,255,0.2); }
.hcc-2 { top: 140px; left: -45px; animation-delay: 1.8s; background: #1e1e1e; color: #c00; border: 2px solid #c00; font-size: 0.8rem; }
.hcc-3 { top: 150px; right: -40px; animation-delay: 0.9s; background: linear-gradient(135deg, #0078d4, #005a9e); color: white; border: 1px solid rgba(255,255,255,0.2); }
.hcc-4 { bottom: -20px; left: 130px; animation-delay: 1.5s; background: linear-gradient(135deg, #e31837, #ff2a4b); color: white; border: 1px solid rgba(255,255,255,0.2); }

/* Stats bar */
.stats-bar{
  position:relative;z-index:2;
  border-top:1px solid var(--border);
  background:rgba(7,7,15,.6);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  padding:2rem 0;margin-top:auto;
}
.stats-inner{display:flex;align-items:center;justify-content:space-around;gap:1rem;flex-wrap:wrap}
.stat{text-align:center}
.stat-num{font-family:'Outfit',sans-serif;font-size:2.2rem;font-weight:800;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat span:last-of-type{font-size:1.5rem;font-weight:700;color:var(--accent)}
.stat p{color:var(--muted);font-size:.8rem;margin-top:.25rem}
.stat-divider{width:1px;height:50px;background:var(--border)}

/* ─────────────────────────────────────────────────
   ABOUT
───────────────────────────────────────────────── */
#about{padding:7rem 0}
.about-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:3rem;align-items:start}
.about-text p{color:var(--muted);line-height:1.85;margin-bottom:1.1rem}
.about-facts{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem}
.fact{
  display:flex;align-items:center;gap:1rem;
  padding:.75rem 1rem;background:var(--surface);
  border:1px solid var(--border);border-radius:.75rem;font-size:.9rem;
}
.fact .mono{flex-shrink:0}
.fact-link{color:var(--accent);transition:opacity .2s}
.fact-link:hover{opacity:.75}
.skills-panel{padding:2rem}
.skills-panel h3{font-size:1.05rem;font-weight:700;margin-bottom:1.5rem}
.skill-item{margin-bottom:1.2rem}
.skill-label{display:flex;justify-content:space-between;font-size:.82rem;margin-bottom:.5rem;color:var(--muted)}
.skill-bar{height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.skill-fill{height:100%;background:var(--grad);border-radius:3px;width:0;transition:width 1.3s var(--ease)}
.tech-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:.5rem;margin-top:1.5rem;
}
.tech-item{
  display:flex;align-items:center;gap:.5rem;
  font-size:.8rem;color:var(--muted);
  padding:.5rem .75rem;
  background:rgba(var(--a-rgb),.06);
  border:1px solid rgba(var(--a-rgb),.12);
  border-radius:.5rem;
}

/* ─────────────────────────────────────────────────
   SERVICES
───────────────────────────────────────────────── */
#services{padding:7rem 0;background:var(--bg2)}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.service-card{
  padding:2rem;transition:transform .3s var(--ease),border-color .3s;
  position:relative;overflow:hidden;
}
.service-card::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at top left,rgba(var(--a-rgb),.1),transparent 70%);
  opacity:0;transition:opacity .3s;
}
.service-card:hover{transform:translateY(-6px);border-color:rgba(var(--a-rgb),.3)}
.service-card:hover::before{opacity:1}
.service-icon{font-size:2.2rem;margin-bottom:1.25rem}
.service-card h3{font-size:1.15rem;margin-bottom:.75rem}
.service-card p{color:var(--muted);font-size:.9rem;line-height:1.75}

/* ─────────────────────────────────────────────────
   PROJECTS — BENTO GRID
───────────────────────────────────────────────── */
#projects{padding:7rem 0}
.projects-bento{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-template-rows:auto auto;
  gap:1.5rem;
}
.p-card{
  position:relative;overflow:hidden;padding:2rem;
  transition:transform .35s var(--ease),border-color .35s;
  cursor:pointer;
}
.p-card:hover{transform:translateY(-8px);border-color:rgba(var(--a-rgb),.35)}
.p-glow{
  position:absolute;top:-60px;right:-60px;
  width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,hsl(var(--card-hue),70%,60%,.3),transparent 70%);
  pointer-events:none;transition:opacity .3s;
  opacity:0;
}
.p-card:hover .p-glow{opacity:1}
.p-large{grid-column:span 2;grid-row:span 1}
.p-tall{grid-column:span 1;grid-row:span 2}
.p-small{grid-column:span 1}
.p-tag{
  display:inline-block;font-size:.7rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--accent);background:rgba(var(--a-rgb),.12);
  padding:.3rem .8rem;border-radius:2rem;margin-bottom:1rem;
}
.p-card h3{font-size:1.3rem;margin-bottom:.75rem}
.p-card p{color:var(--muted);font-size:.88rem;line-height:1.75;margin-bottom:1.5rem}
.p-tech{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.p-tech span{
  font-size:.75rem;color:var(--muted);
  background:var(--border);padding:.3rem .7rem;border-radius:.4rem;
}
.p-link{
  font-size:.85rem;font-weight:700;color:var(--accent);
  display:inline-flex;align-items:center;gap:.3rem;
  transition:gap .2s;
}
.p-link:hover{gap:.6rem}

/* ─────────────────────────────────────────────────
   EXPERIENCE
───────────────────────────────────────────────── */
#experience{padding:7rem 0;background:var(--bg2)}
.timeline{max-width:800px;position:relative;padding-left:2rem}
.timeline-track{
  position:absolute;left:0;top:0;bottom:0;width:2px;
  background:linear-gradient(to bottom,transparent,var(--accent),var(--accent2),transparent);
  opacity:.3;
}
.timeline-item{position:relative;margin-bottom:2.5rem}
.tl-dot{
  position:absolute;left:-2.5rem;top:1.75rem;
  width:14px;height:14px;border-radius:50%;
  background:var(--grad);
  box-shadow:0 0 12px rgba(var(--a-rgb),.7);
}
.tl-dot-active{
  animation: pulse-dot-tl 2s infinite;
}
@keyframes pulse-dot-tl{
  0%,100%{box-shadow:0 0 0 0 rgba(var(--a-rgb),0.6), 0 0 12px rgba(var(--a-rgb),0.8);}
  50%{box-shadow:0 0 0 8px rgba(var(--a-rgb),0), 0 0 20px rgba(var(--a-rgb),1);}
}
.tl-card{padding:1.75rem 2rem}
.tl-header{
  display:flex;justify-content:space-between;
  align-items:flex-start;gap:1rem;margin-bottom:1rem;flex-wrap:wrap;
}
.tl-header h3{font-size:1.1rem}
.tl-company{color:var(--accent);font-size:.85rem;margin-top:.25rem}
.tl-date{
  font-size:.78rem;color:var(--muted);white-space:nowrap;
  padding:.3rem .85rem;background:var(--surface);
  border:1px solid var(--border);border-radius:2rem;
}
.tl-card>p{color:var(--muted);font-size:.88rem;line-height:1.75;margin-bottom:1rem}
.tl-tags{display:flex;gap:.5rem;flex-wrap:wrap}
.tl-tags span{
  font-size:.75rem;color:var(--muted);
  background:var(--surface);border:1px solid var(--border);
  padding:.25rem .65rem;border-radius:.4rem;
}

/* ─────────────────────────────────────────────────
   INFRASTRUCTURE
───────────────────────────────────────────────── */
.infra-showcase {
    display: flex;
    flex-direction: column;
    gap: 3rem;
}
.infra-banner {
    position: relative;
    width: 100%;
    height: 350px;
    border-radius: 1.5rem;
    overflow: hidden;
    border: 1px solid var(--border);
    background: #000;
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
}
.infra-banner img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: brightness(0.9);
    transition: transform 0.8s var(--ease);
}
.infra-banner:hover img {
    transform: scale(1.02);
}
.infra-banner-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(2,2,4,1) 0%, transparent 80%);
    pointer-events: none;
}
.infra-banner-text {
    position: absolute;
    bottom: 2rem;
    left: 2.5rem;
    z-index: 2;
}
.infra-banner-text h3 {
    font-size: 1.7rem;
    margin-bottom: 0.5rem;
    text-shadow: 0 2px 10px rgba(0,0,0,0.8);
}
.infra-banner-text p {
    color: var(--muted);
    font-size: 0.95rem;
    text-shadow: 0 2px 10px rgba(0,0,0,0.8);
}
.infra-details {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: center;
}

/* ─────────────────────────────────────────────────
   CONTACT
───────────────────────────────────────────────── */
#contact{padding:7rem 0}
.contact-wrapper{display:grid;grid-template-columns:1fr 1.3fr;gap:4rem;align-items:start}
.contact-headline{font-family:'Outfit',sans-serif;font-size:1.5rem;font-weight:700;margin-bottom:1rem}
.contact-sub{color:var(--muted);line-height:1.8;margin-bottom:2.5rem;font-size:.95rem}
.contact-methods{display:flex;flex-direction:column;gap:1rem}
.c-method{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.25rem;background:var(--surface);
  border:1px solid var(--border);border-radius:.9rem;
  transition:border-color .25s,transform .25s;
}
.c-method:hover{border-color:rgba(var(--a-rgb),.4);transform:translateX(4px)}
.c-method-icon{
  width:40px;height:40px;border-radius:.6rem;
  display:flex;align-items:center;justify-content:center;
  background:rgba(var(--a-rgb),.12);color:var(--accent);flex-shrink:0;
}
.c-method-label{font-size:.75rem;color:var(--muted);margin-bottom:.15rem}
.c-method-value{font-size:.9rem;font-weight:500}
.contact-form{padding:2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.form-group{margin-bottom:1.25rem}
.form-group label{
  display:block;font-size:.75rem;font-weight:600;
  margin-bottom:.5rem;color:var(--muted);
  letter-spacing:.06em;text-transform:uppercase;
}
input,textarea{
  width:100%;padding:.9rem 1rem;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);border-radius:.65rem;
  color:var(--text);font-family:'Inter',sans-serif;font-size:.9rem;
  transition:border-color .25s,background .25s;resize:vertical;
}
input:focus,textarea:focus{
  outline:none;border-color:var(--accent);
  background:rgba(255,255,255,.05);
}
input::placeholder,textarea::placeholder{color:var(--muted)}

/* ─────────────────────────────────────────────────
   FOOTER
───────────────────────────────────────────────── */
footer{
  padding:3rem 0;
  border-top:1px solid var(--border);
  background:var(--bg);
}
.footer-inner{
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;gap:2rem;
}
.footer-left p{color:var(--muted);font-size:.82rem;margin-top:.35rem}
.footer-nav{display:flex;justify-content:center;gap:2rem}
.footer-nav a{color:var(--muted);font-size:.85rem;transition:color .2s}
.footer-nav a:hover{color:var(--text)}
.footer-copy{color:var(--muted);font-size:.82rem;text-align:right}

/* ─────────────────────────────────────────────────
   SELF-HOSTED BADGE
───────────────────────────────────────────────── */
.self-host-badge {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 850;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: rgba(7, 7, 15, 0.8);
  border: 1px solid rgba(var(--a-rgb), 0.3);
  border-radius: 1rem;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  text-decoration: none;
  transition: all 0.3s var(--ease);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
  cursor: pointer;
  text-align: left;
}
.self-host-badge:hover {
  transform: translateY(-5px);
  border-color: var(--accent);
  box-shadow: 0 8px 25px rgba(var(--a-rgb), 0.25);
}
.sh-text {
  display: flex;
  flex-direction: column;
}
.sh-title {
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.1;
}
.sh-sub {
  font-size: 0.65rem;
  color: var(--muted);
  margin-top: 0.15rem;
}

/* ─────────────────────────────────────────────────
   INFRASTRUCTURE MODAL
───────────────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(2, 2, 4, 0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s var(--ease);
}
.modal-overlay.active {
  opacity: 1;
  pointer-events: auto;
}
.modal-content {
  max-width: 900px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
  padding: 3rem;
  position: relative;
  transform: translateY(30px) scale(0.95);
  transition: transform 0.4s var(--ease);
}
.modal-overlay.active .modal-content {
  transform: translateY(0) scale(1);
}
.modal-close {
  position: absolute;
  top: 1.5rem;
  right: 1.5rem;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
  color: var(--text);
  font-size: 1.5rem;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
  z-index: 10;
}
.modal-close:hover {
  background: rgba(var(--a-rgb), 0.2);
  color: var(--accent);
}

/* Custom Scrollbar for Modal Body */
.modal-body::-webkit-scrollbar {
  width: 6px;
}
.modal-body::-webkit-scrollbar-track {
  background: transparent;
  margin: 1rem 0;
}
.modal-body::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.15);
  border-radius: 4px;
}
.modal-body::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.3);
}

/* ─────────────────────────────────────────────────
   CERTIFICATIONS
───────────────────────────────────────────────── */
.cert-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.5rem;
  margin-top: 2.5rem;
}
.cert-card {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  padding: 1.5rem;
  border-radius: 1rem;
  transition: transform 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.cert-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 8px 25px rgba(var(--a-rgb), 0.15);
  border-color: rgba(var(--a-rgb), 0.4);
}
.cert-logo {
  width: 60px;
  height: 60px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-weight: 800;
  font-size: 1.2rem;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
}

/* Specific Vendor Styles */
.cert-logo.comptia-net {
  background: linear-gradient(135deg, #0055a4, #0072ce);
  color: white;
  font-size: 1rem;
}
.cert-logo.comptia-sec {
  background: linear-gradient(135deg, #e31837, #ff2a4b);
  color: white;
  font-size: 1rem;
}
.cert-logo.azure {
  background: linear-gradient(135deg, #0078d4, #005a9e);
  color: white;
}
.cert-logo.ceh {
  background: #1e1e1e;
  color: #c00;
  border: 2px solid #c00;
  border-radius: 50%;
  font-size: 1.1rem;
}
.cert-logo.fortinet {
  background: #c00;
  color: white;
}
.cert-logo.pentesterlab {
  background: #2a2a2a;
  color: #fff;
  border: 1px solid #444;
  font-size: 1.1rem;
}
.cert-info h3 {
  font-size: 1.1rem;
  margin-bottom: 0.25rem;
  color: var(--text);
}
.cert-info p {
  font-size: 0.85rem;
  color: var(--muted);
  margin-bottom: 0.15rem;
}

/* ─────────────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────────────── */
@media(max-width:1024px){
  .projects-bento{grid-template-columns:1fr 1fr}
  .p-large{grid-column:span 2}
  .p-tall{grid-column:span 1;grid-row:span 1}
}
@media(max-width:860px){
  .hero-inner{grid-template-columns:1fr}
  .hero-card-stack{display:none}
  .about-grid{grid-template-columns:1fr}
  .infra-details{grid-template-columns:1fr;gap:2.5rem}
  .services-grid{grid-template-columns:1fr}
  .contact-wrapper{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;text-align:center}
  .footer-nav{flex-wrap:wrap}
  .footer-copy{text-align:center}
}
@media(max-width:600px){
  .self-host-badge {
    bottom: 1rem;
    right: 1rem;
    padding: 0.6rem 0.8rem;
  }
  .sh-title { font-size: 0.75rem; }
  .sh-sub { font-size: 0.6rem; }
  .nav-links{
    display:none;flex-direction:column;
    position:fixed;inset:0;background:var(--bg);
    justify-content:center;align-items:center;gap:2.5rem;z-index:799;
  }
  .nav-links.open{display:flex}
  .nav-links a{font-size:1.3rem}
  .hamburger{display:flex;z-index:900;position:relative}
  .projects-bento{grid-template-columns:1fr}
  .p-large,.p-tall,.p-small{grid-column:span 1;grid-row:span 1}
  .stats-inner{justify-content:center;gap:1.5rem}
  .stat-divider{display:none}
  .hero-text h1{font-size:2.75rem}
}
