/* styles.css - extracted from index.html */

:root {
  --ease: cubic-bezier(.16,1,.3,1);
  --bg:#080e10; --bg2:#0d1719; --bg3:#111f22;
  --surface:#162226; --border:rgba(99,215,190,.10);
  --text:#e8f4f1; --muted:#7ba89e;
  --accent:#3ecfad; --accent2:#5fa8e8; --accent3:#c979e0;
  --glow:rgba(62,207,173,.18);
}
[data-theme="light"] {
  --bg:#f0f7f5; --bg2:#e4efec; --bg3:#d6e8e4;
  --surface:#ffffff; --border:rgba(20,100,85,.14);
  --text:#0e2420; --muted:#527d74;
  --accent:#0d9e81; --accent2:#2474c4; --accent3:#9e3dbd;
  --glow:rgba(13,158,129,.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Mono',monospace;background:var(--bg);color:var(--text);line-height:1.6;transition:background .4s var(--ease),color .4s var(--ease);overflow-x:hidden}
a{color:inherit;text-decoration:none}
ul{list-style:none}
#bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.5}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1rem 2.5rem;backdrop-filter:blur(18px) saturate(160%);background:rgba(8,14,16,.7);border-bottom:1px solid var(--border);transition:background .4s}
[data-theme="light"] nav{background:rgba(240,247,245,.82)}
.nav-logo{font-family:'Syne',sans-serif;font-weight:800;font-size:1rem;letter-spacing:.01em;color:var(--text)}
.nav-logo span{color:var(--accent)}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);transition:color .2s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.nav-links a:hover{color:var(--text)}.nav-links a:hover::after{transform:scaleX(1)}
#theme-btn{background:none;border:1px solid var(--border);color:var(--muted);cursor:pointer;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:border-color .2s,color .2s,transform .3s var(--ease)}
#theme-btn:hover{border-color:var(--accent);color:var(--accent);transform:rotate(30deg)}

/* HERO */
#hero{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:8rem 2.5rem 5rem;max-width:1100px;margin:0 auto}
.hero-eyebrow{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:1.4rem;display:flex;align-items:center;gap:.6rem}
.hero-eyebrow::before{content:'';display:inline-block;width:2rem;height:1px;background:var(--muted)}
.hero-name{font-family:'DM Serif Display',serif;font-size:clamp(3rem,7vw,6rem);line-height:1.05;letter-spacing:-.02em;margin-bottom:.6rem}
.hero-name .cursive{font-style:italic;color:var(--accent)}
.hero-sub{font-size:clamp(.88rem,2vw,1.05rem);color:var(--muted);max-width:560px;margin-bottom:2.5rem;line-height:1.8}
.hero-sub strong{color:var(--text);font-weight:500}
.hero-pills{display:flex;gap:.7rem;margin-bottom:3rem;flex-wrap:wrap}
.pill{display:flex;align-items:center;gap:.4rem;padding:.38rem .8rem;border:1px solid var(--border);border-radius:2rem;font-size:.7rem;color:var(--muted);background:var(--surface);transition:border-color .25s,color .25s,transform .25s var(--ease)}
.pill:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
.btn{padding:.6rem 1.5rem;border-radius:2rem;font-family:'DM Mono',monospace;font-size:.76rem;letter-spacing:.06em;cursor:pointer;transition:all .25s var(--ease);display:inline-block}
.btn-primary{background:var(--accent);color:#051210;border:1px solid var(--accent)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--glow)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.availability-dot{display:inline-flex;align-items:center;gap:.5rem;font-size:.68rem;color:var(--muted);letter-spacing:.06em}
.availability-dot::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--accent);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.scroll-hint{position:absolute;bottom:2.5rem;left:2.5rem;display:flex;align-items:center;gap:.6rem;font-size:.63rem;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;animation:float 2.5s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

/* SECTIONS */
.section{position:relative;z-index:1;max-width:1100px;margin:0 auto;padding:6rem 2.5rem}
.sec-label{font-size:.63rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:3rem;display:flex;align-items:center;gap:.7rem}
.sec-label::before{content:attr(data-n);font-size:.58rem;color:var(--muted);opacity:.6}
.sec-title{font-family:'DM Serif Display',serif;font-size:clamp(1.8rem,4vw,2.8rem);line-height:1.1;margin-bottom:1rem}
.sec-title em{font-style:italic;color:var(--accent)}
.divider{width:100%;height:1px;background:var(--border);margin-bottom:3.5rem}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}
.reveal-d3{transition-delay:.3s}.reveal-d4{transition-delay:.4s}

/* ABOUT */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.about-text p{color:var(--muted);line-height:1.9;font-size:.87rem;margin-bottom:1.1rem}
.about-text p strong{color:var(--text)}
.cards-2x2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.interest-card{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:1.2rem;transition:border-color .25s,transform .25s var(--ease)}
.interest-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.ic-emoji{font-size:1.4rem;margin-bottom:.5rem;display:block}
.ic-title{font-family:'Syne',sans-serif;font-weight:700;font-size:.8rem;color:var(--text);margin-bottom:.25rem}
.ic-desc{font-size:.7rem;color:var(--muted);line-height:1.55}

/* SKILLS */
.skills-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1.5rem}
.skill-group{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:1.4rem;transition:border-color .25s,transform .25s var(--ease)}
.skill-group:hover{border-color:var(--accent2);transform:translateY(-3px)}
.skill-group-title{font-family:'Syne',sans-serif;font-weight:700;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--accent2);margin-bottom:.9rem}
.skill-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.skill-tag{font-size:.67rem;padding:.22rem .58rem;border-radius:2rem;border:1px solid var(--border);color:var(--muted);background:var(--bg3);transition:border-color .2s,color .2s}
.skill-tag:hover{border-color:var(--accent2);color:var(--accent2)}

/* EXPERIENCE */
.exp-list{position:relative}
.exp-list::before{content:'';position:absolute;left:0;top:4px;bottom:0;width:1px;background:var(--border)}
.exp-item{padding:0 0 2.8rem 2rem;position:relative}
.exp-item::before{content:'';position:absolute;left:-4px;top:5px;width:9px;height:9px;border-radius:50%;background:var(--accent);border:2px solid var(--bg)}
.exp-period{font-size:.63rem;letter-spacing:.12em;color:var(--muted);text-transform:uppercase;margin-bottom:.4rem}
.exp-role{font-family:'Syne',sans-serif;font-weight:700;font-size:.98rem;margin-bottom:.2rem}
.exp-type{font-size:.58rem;padding:.12rem .45rem;border:1px solid var(--border);border-radius:2rem;color:var(--muted);margin-left:.4rem;font-family:'DM Mono',monospace;vertical-align:middle}
.exp-company{font-size:.8rem;color:var(--accent);margin-bottom:.7rem}
.exp-desc{font-size:.8rem;color:var(--muted);line-height:1.8;max-width:680px}
.exp-desc li{list-style:disc;list-style-position:outside;margin-left:1rem;margin-bottom:.3rem}

/* PROJECTS */
.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.4rem}
.project-card{background:var(--surface);border:1px solid var(--border);border-radius:1.2rem;padding:1.6rem;display:flex;flex-direction:column;gap:.7rem;transition:border-color .25s,transform .3s var(--ease),box-shadow .3s;position:relative;overflow:hidden}
.project-card::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at top left,var(--glow),transparent 70%);opacity:0;transition:opacity .3s}
.project-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.2)}
.project-card:hover::before{opacity:1}
.project-header{display:flex;justify-content:space-between;align-items:flex-start}
.project-icon{font-size:1.5rem}
.project-link-btn{font-size:.68rem;color:var(--muted);padding:.2rem .5rem;border:1px solid var(--border);border-radius:.4rem;transition:color .2s,border-color .2s}
.project-link-btn:hover{color:var(--accent);border-color:var(--accent)}
.project-cat{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent3)}
.project-name{font-family:'Syne',sans-serif;font-weight:700;font-size:.95rem;line-height:1.2}
.project-desc{font-size:.78rem;color:var(--muted);line-height:1.72;flex:1}

/* CERTIFICATIONS */
.certs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.2rem}
.cert-card{background:var(--surface);border:1px solid var(--border);border-radius:1rem;padding:1.3rem;display:flex;gap:1rem;align-items:flex-start;transition:border-color .25s,transform .25s var(--ease)}
.cert-card:hover{border-color:var(--accent3);transform:translateY(-3px)}
.cert-icon{font-size:1.5rem;flex-shrink:0}
.cert-name{font-family:'Syne',sans-serif;font-weight:700;font-size:.82rem;margin-bottom:.2rem}
.cert-issuer{font-size:.7rem;color:var(--accent3)}
.cert-date{font-size:.65rem;color:var(--muted);margin-top:.15rem}

/* CONTACT */
.contact-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.contact-blurb{font-size:.87rem;color:var(--muted);line-height:1.85;margin-bottom:2rem}
.contact-blurb strong{color:var(--text)}
.contact-email{font-family:'DM Serif Display',serif;font-size:1.25rem;color:var(--accent);display:inline-flex;align-items:center;gap:.5rem;transition:gap .25s var(--ease)}
.contact-email:hover{gap:1rem}
.contact-email::after{content:'→'}
.socials-title{font-size:.63rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:1.2rem}
.socials-grid{display:flex;flex-direction:column;gap:.65rem}
.social-item{display:flex;align-items:center;gap:1rem;padding:.7rem 1rem;border-radius:.75rem;border:1px solid var(--border);background:var(--surface);transition:border-color .25s,transform .25s var(--ease)}
.social-item:hover{border-color:var(--accent);transform:translateX(6px)}
.social-icon{font-size:1rem;width:1.4rem;text-align:center}
.social-handle{font-size:.76rem;color:var(--muted)}
.social-name{font-size:.66rem;color:var(--muted);opacity:.55;margin-left:auto}

/* FOOTER */
footer{position:relative;z-index:1;border-top:1px solid var(--border);padding:1.5rem 2.5rem;display:flex;justify-content:space-between;align-items:center;font-size:.66rem;color:var(--muted)}
.footer-heart{color:var(--accent)}

@media(max-width:768px){
  nav{padding:.9rem 1.2rem}.nav-links{display:none}
  #hero{padding:7rem 1.2rem 4rem}.section{padding:4rem 1.2rem}
  .two-col,.contact-inner{grid-template-columns:1fr;gap:2.5rem}
  .cards-2x2{grid-template-columns:1fr 1fr}
  footer{flex-direction:column;gap:.5rem;text-align:center}
}
