/* ─── RESET ──────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#080b06;
  --bg2:#0c0f09;
  --glass:rgba(14,18,10,.6);
  --glass2:rgba(18,24,12,.45);
  --g:#8BB858;
  --g2:#6FA043;
  --gd:#5A8A38;
  --gg:rgba(139,184,88,.15);
  --gg2:rgba(139,184,88,.06);
  --t1:#f2f4ef;
  --t2:#c2cfb5;
  --t3:#8a9a7c;
  --b1:rgba(139,184,88,.1);
  --b2:rgba(139,184,88,.2);
  --b3:rgba(232,236,228,.04);
  --max:1100px;
  --r:14px;
  --rs:8px;
  --sans:'Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',monospace;
  --ease:cubic-bezier(.4,0,.2,1);
  --dur:.24s;
}

html{scroll-behavior:smooth;scroll-padding-top:72px;overflow-x:hidden}
body{font-family:var(--sans);background:var(--bg);color:var(--t1);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;position:relative;width:100%}

/* Page-level overflow containment */
#page-wrapper{overflow-x:clip;width:100%;position:relative}
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;background:
  radial-gradient(ellipse 80% 60% at 20% 10%, rgba(139,184,88,.07) 0%, transparent 50%),
  radial-gradient(ellipse 70% 50% at 80% 30%, rgba(90,138,56,.06) 0%, transparent 50%),
  radial-gradient(ellipse 60% 80% at 50% 80%, rgba(111,160,67,.05) 0%, transparent 50%),
  radial-gradient(ellipse 90% 40% at 10% 60%, rgba(139,184,88,.04) 0%, transparent 50%);
  animation:bgShift 30s ease-in-out infinite alternate}
body::after{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:.03;mix-blend-mode:overlay}
@keyframes bgShift{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}100%{opacity:1;transform:scale(1)}}

/* Vignette */
.vignette{position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,.4) 100%)}

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
strong{color:var(--t1);font-weight:600}
.mono{font-family:var(--mono)}
.grad-text{background:linear-gradient(135deg,var(--g),#c4d9a8,var(--g2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gd);border-radius:99px}

/* ─── CANVAS BG ──────────────────────────────────────────────────── */
#bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.55}

/* ─── AURORA BLOBS ───────────────────────────────────────────────── */
.aurora{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.aurora-blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.15;animation:auroraFloat 20s ease-in-out infinite alternate}
.aurora-blob-1{width:400px;height:400px;background:radial-gradient(circle,var(--g),transparent 70%);top:-15%;left:-10%;animation-duration:22s}
.aurora-blob-2{width:350px;height:350px;background:radial-gradient(circle,var(--g2),transparent 70%);bottom:-20%;right:-10%;animation-delay:-8s;animation-duration:26s}
.aurora-blob-3{width:300px;height:300px;background:radial-gradient(circle,var(--gd),transparent 70%);top:45%;left:40%;animation-delay:-14s;animation-duration:30s}
@keyframes auroraFloat{0%{transform:translate(0,0) scale(1)}33%{transform:translate(50px,-60px) scale(1.15)}66%{transform:translate(-40px,50px) scale(.85)}100%{transform:translate(20px,-30px) scale(1.1)}}

/* ─── NAV (mobile-first) ────────────────────────────────────────── */
#navbar{position:fixed;top:0;left:0;right:0;width:100%;z-index:100;height:60px;transition:background var(--dur),border-color var(--dur);border-bottom:1px solid transparent}
#navbar.scrolled{background:rgba(8,11,6,.92);backdrop-filter:blur(20px) saturate(180%);border-color:var(--b1)}
.nav-inner{max-width:var(--max);margin:0 auto;height:100%;display:flex;align-items:center;gap:.75rem;padding:0 1.25rem}
.nav-logo-img{width:44px;height:44px;border-radius:10px;object-fit:contain}

/* Hide desktop nav links & CV button on mobile */
.nav-links{display:none;list-style:none;gap:.1rem;margin-left:auto}
.btn-nav{display:none;align-items:center;gap:.35rem;padding:.32rem .8rem;font-size:.75rem;font-weight:600;color:var(--g);border:1px solid var(--b2);border-radius:var(--rs);transition:background var(--dur),color var(--dur);white-space:nowrap;flex-shrink:0}
.btn-nav:hover{background:var(--g);color:#030f08;border-color:var(--g)}

/* Hamburger visible by default */
.hamburger{display:flex;flex-direction:column;gap:4px;padding:5px;background:none;border:none;cursor:pointer;margin-left:auto}
.hamburger span{display:block;width:18px;height:1.5px;background:var(--t2);border-radius:99px;transition:var(--dur)}

.nav-links a{padding:.28rem .65rem;font-size:.78rem;font-weight:500;color:var(--t2);border-radius:var(--rs);transition:color var(--dur),background var(--dur)}
.nav-links a:hover,.nav-links a.active{color:var(--g);background:var(--gg2)}

/* ─── MOBILE NAV OPEN ────────────────────────────────────────────── */
#navbar.mobile-open .nav-links{display:flex;flex-direction:column;position:fixed;top:60px;left:0;right:0;background:rgba(5,10,8,.97);backdrop-filter:blur(20px);padding:1rem 1.25rem;border-bottom:1px solid var(--b1);gap:.2rem;z-index:99}
#navbar.mobile-open .nav-links a{font-size:.9rem;padding:.6rem .5rem}

/* ─── HERO (mobile-first) ───────────────────────────────────────── */
#hero{position:relative;z-index:1;min-height:100svh;display:flex;align-items:center;padding:5rem 1.25rem 3rem;overflow:hidden}

.hero-inner{max-width:var(--max);margin:0 auto;width:100%;display:flex;flex-direction:column;align-items:center;text-align:center;gap:2rem}

/* On mobile: text first, visual second */
.hero-text{order:1}
.hero-visual{order:0}

/* Badge */
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.28rem .8rem;background:var(--glass);border:1px solid var(--b1);border-radius:99px;font-size:.65rem;font-weight:500;color:var(--g);backdrop-filter:blur(8px);width:fit-content;margin-bottom:1rem;justify-content:center}
.pulse-dot{width:6px;height:6px;border-radius:50%;background:var(--g);flex-shrink:0;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(139,184,88,.4)}50%{box-shadow:0 0 0 6px rgba(139,184,88,0)}}

/* Heading */
.hero-h1{margin-bottom:1rem}
.hero-greeting{display:block;font-size:.9rem;font-weight:500;color:var(--t2);margin-bottom:.3rem;opacity:0;animation:fadeSlideIn .8s var(--ease) .2s forwards}
.hero-title{display:block;font-size:2.6rem;font-weight:900;letter-spacing:-.05em;line-height:.95;opacity:0;animation:fadeSlideIn .8s var(--ease) .4s forwards}
.hero-dot{color:var(--g)}

/* Gradient shimmer */
.grad-text{background-size:200% 100%;animation:shimmer 4s ease-in-out infinite}
@keyframes shimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.hero-desc{font-size:.85rem;color:var(--t2);max-width:440px;line-height:1.75;margin-bottom:1.5rem;margin-inline:auto;opacity:0;animation:fadeSlideIn .8s var(--ease) .6s forwards}

/* CTA */
.hero-cta{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.25rem;justify-content:center}

.btn-glow{display:inline-flex;align-items:center;gap:.5rem;padding:.52rem 1.2rem;background:var(--g);color:#020e07;font-size:.8rem;font-weight:700;border-radius:var(--rs);border:none;cursor:pointer;box-shadow:0 0 0 0 var(--gg);transition:box-shadow .3s,transform .3s;position:relative;overflow:hidden}
.btn-glow::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.2) 50%,transparent 60%);transform:translateX(-100%);transition:none}
.btn-glow:hover{transform:translateY(-2px);box-shadow:0 0 30px var(--gg),0 6px 24px rgba(0,0,0,.3)}
.btn-glow:hover::after{transform:translateX(100%);transition:transform .6s}

.btn-glass{display:inline-flex;align-items:center;gap:.5rem;padding:.52rem 1.2rem;background:var(--glass);color:var(--t1);font-size:.8rem;font-weight:600;border-radius:var(--rs);border:1px solid var(--b3);cursor:pointer;backdrop-filter:blur(8px);transition:border-color var(--dur),background var(--dur)}
.btn-glass:hover{border-color:var(--b2);background:var(--gg2)}

.btn-lg{padding:.65rem 1.5rem;font-size:.88rem}

/* Contact links */
.hero-links{display:flex;flex-direction:column;gap:.35rem;align-items:center}
.hero-link{display:flex;align-items:center;gap:.4rem;font-size:.75rem;color:var(--t3);transition:color var(--dur)}
.hero-link:hover{color:var(--g)}
.hero-link svg{flex-shrink:0}

/* ── Hero Visual: ORB (mobile-first — small) ── */
.hero-visual{display:flex;justify-content:center;align-items:center;position:relative;min-height:200px}

.hero-orb{position:relative;width:140px;height:140px;display:flex;align-items:center;justify-content:center}
.hero-orb-img{width:110px;height:110px;border-radius:50%;position:relative;z-index:2;box-shadow:0 0 50px rgba(139,184,88,.12),0 0 100px rgba(139,184,88,.05);animation:orbGlow 4s ease-in-out infinite;object-fit:contain;background:rgba(8,11,6,.75);padding:12px}
@keyframes orbGlow{0%,100%{box-shadow:0 0 50px rgba(139,184,88,.12),0 0 100px rgba(139,184,88,.05)}50%{box-shadow:0 0 65px rgba(139,184,88,.2),0 0 130px rgba(139,184,88,.08)}}

.orb-ring{position:absolute;border-radius:50%;border:1.5px solid;animation:orbSpin 14s linear infinite}
.orb-ring-1{inset:-20px;border-color:rgba(139,184,88,.18);box-shadow:0 0 8px rgba(139,184,88,.05)}
.orb-ring-2{inset:-42px;border-color:rgba(139,184,88,.1);animation-direction:reverse;animation-duration:22s;box-shadow:0 0 6px rgba(139,184,88,.03)}
.orb-ring-3{inset:-64px;border-color:rgba(139,184,88,.06);animation-duration:32s}
@keyframes orbSpin{to{transform:rotate(360deg)}}

/* Floating stat badges — hidden on mobile */
.hero-float{display:none;position:absolute;flex-direction:column;align-items:center;gap:.1rem;padding:.5rem .8rem;background:var(--glass);border:1px solid var(--b1);border-radius:var(--r);backdrop-filter:blur(12px);box-shadow:0 8px 32px rgba(0,0,0,.25);white-space:nowrap;animation:floatY 4s ease-in-out infinite;transition:transform .3s,box-shadow .3s}
.hero-float:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 40px rgba(0,0,0,.3),0 0 20px rgba(139,184,88,.08)}
.hf-num{font-size:1.15rem;font-weight:800;color:var(--g);line-height:1;font-family:var(--sans);letter-spacing:-.03em}
.hf-text{font-size:.55rem;font-weight:500;color:var(--t3);text-transform:uppercase;letter-spacing:.08em}

.hf-1{top:5%;right:-10px;animation-delay:0s}
.hf-2{bottom:10%;left:-20px;animation-delay:-1.5s}
.hf-3{top:52%;right:-30px;animation-delay:-3s}

@keyframes floatY{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px)}}

/* Scroll cue */
.scroll-cue{position:absolute;bottom:1.5rem;left:50%;transform:translateX(-50%)}
.scroll-line{width:1px;height:36px;background:linear-gradient(to bottom,var(--g),transparent);animation:scrollFade 2s ease-in-out infinite}
@keyframes scrollFade{0%{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.5)}100%{opacity:1;transform:scaleY(1)}}

/* ─── SECTIONS (mobile-first) ────────────────────────────────────── */
.section{position:relative;z-index:1;padding:3.5rem 1.25rem;overflow:hidden}
.section-alt{background:var(--bg2)}
.container{max-width:var(--max);margin:0 auto}
.tag-label{display:inline-block;margin-bottom:.5rem;font-family:var(--mono);font-size:.65rem;font-weight:600;color:var(--g);letter-spacing:.14em;text-transform:uppercase}
.sec-h{font-size:1.6rem;font-weight:800;letter-spacing:-.035em;line-height:1.1;margin-bottom:2rem}
.sec-h-xl{font-size:1.8rem;margin-bottom:1rem}

/* Fade — staggered */
.fade-up{opacity:0;transform:translateY(30px)}
.fade-up.visible{opacity:1;transform:translateY(0);transition:opacity .7s var(--ease),transform .7s var(--ease)}

/* Section divider */
.section-divider{height:1px;border:none;background:linear-gradient(90deg,transparent,var(--b2),var(--g),var(--b2),transparent);opacity:.4;margin:0;background-size:200% 100%;animation:dividerSlide 6s linear infinite}
@keyframes dividerSlide{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ─── ABOUT (mobile-first) ──────────────────────────────────────── */
.about-grid{display:flex;flex-direction:column;gap:1.5rem}
.about-right p{font-size:.88rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem}
.about-meta{display:grid;grid-template-columns:1fr;gap:.65rem}
.am{display:flex;flex-direction:column;gap:.15rem}
.am-label{font-family:var(--mono);font-size:.6rem;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.1em}
.am-value{font-size:.82rem;color:var(--t2)}

/* ─── EXPERIENCE (mobile-first) ──────────────────────────────────── */
.exp-list{display:flex;flex-direction:column;gap:1rem}
.exp-card{display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;background:var(--glass);border:1px solid var(--b1);border-radius:var(--r);backdrop-filter:blur(8px);transition:border-color .3s,box-shadow .3s,transform .3s}
.exp-card:hover{border-color:var(--b2);box-shadow:0 0 24px var(--gg2);transform:translateY(-2px)}
.exp-side{display:flex;flex-direction:column;gap:.35rem}
.exp-date{font-size:.72rem;color:var(--t3)}
.exp-current{display:inline-flex;width:fit-content;padding:.12rem .5rem;font-size:.6rem;font-weight:700;color:var(--g);background:var(--gg2);border:1px solid var(--b1);border-radius:99px;font-family:var(--mono)}
.exp-body h3{font-size:.95rem;font-weight:700;color:var(--t1);margin-bottom:.15rem}
.exp-co{font-size:.78rem;color:var(--g);font-weight:500;margin-bottom:.65rem}
.exp-body ul{list-style:none}
.exp-body li{position:relative;padding-left:.85rem;margin-bottom:.3rem;font-size:.8rem;color:var(--t2);line-height:1.6}
.exp-body li::before{content:'·';position:absolute;left:0;color:var(--g);font-weight:700}
.exp-body strong{color:var(--t1)}

/* ─── PROJECT SWIPER (mobile-first) ──────────────────────────────── */
.proj-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1.25rem;gap:1rem}
.proj-arrows{display:flex;gap:.4rem}
.arrow-btn{width:36px;height:36px;border-radius:50%;background:var(--glass);border:1px solid var(--b1);color:var(--t2);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color var(--dur),color var(--dur),background var(--dur);backdrop-filter:blur(8px)}
.arrow-btn:hover{border-color:var(--b2);color:var(--g);background:var(--gg2)}
.arrow-btn svg{width:15px;height:15px}

#proj-swiper{overflow:visible;padding-bottom:2.5rem}
#proj-swiper .swiper-slide{height:auto}

/* Project card — VERTICAL */
.pc{display:flex;flex-direction:column;background:var(--glass);border:1px solid var(--b1);border-radius:var(--r);backdrop-filter:blur(12px);height:100%;overflow:hidden;transition:border-color var(--dur),box-shadow var(--dur),transform var(--dur)}
.pc:hover{border-color:var(--b2);box-shadow:0 8px 32px rgba(52,211,153,.08);transform:translateY(-3px)}

/* Logo banner — top of card */
.pc-logo-banner{width:100%;height:100px;background:var(--bg2);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--b1);overflow:hidden}
.pc-logo-banner img{width:100%;height:100%;object-fit:contain;padding:1.2rem}
.pc-logo-banner-txt{background:linear-gradient(135deg,rgba(52,211,153,.06),var(--bg2))}
.pc-logo-banner-txt span{font-family:var(--mono);font-size:1.5rem;font-weight:800;color:var(--g);letter-spacing:.1em}

/* Card body */
.pc-body{display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.2rem 1.2rem;flex:1}

.pc-meta{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}
.pc-date{font-size:.6rem;color:var(--t3);font-family:var(--mono)}
.pc-role{font-size:.58rem;font-weight:600;color:var(--g);background:var(--gg2);border:1px solid var(--b1);padding:.1rem .45rem;border-radius:99px;font-family:var(--mono);white-space:nowrap}

.pc-title{font-size:.88rem;font-weight:700;color:var(--t1)}
.pc-desc{font-size:.76rem;color:var(--t2);line-height:1.65}

.pc-tags{display:flex;flex-wrap:wrap;gap:.25rem}
.pc-tags span{font-size:.58rem;font-weight:500;color:var(--t3);background:var(--b3);padding:.12rem .38rem;border-radius:3px;font-family:var(--mono)}

/* Visit link */
.pc-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:auto;padding:.4rem 0;font-size:.75rem;font-weight:600;color:var(--g);transition:opacity var(--dur);cursor:pointer}
.pc-link:hover{opacity:.75}
.pc-link svg{flex-shrink:0;transition:transform var(--dur)}
.pc-link:hover svg{transform:translate(2px,-2px)}

/* Swiper pagination override */
.swiper-pagination{bottom:0 !important}
.swiper-pagination-bullet{width:6px;height:6px;background:var(--t3);opacity:1;transition:background var(--dur),transform var(--dur)}
.swiper-pagination-bullet-active{background:var(--g);transform:scale(1.4)}

/* ─── SKILLS (mobile-first) ──────────────────────────────────────── */
.skill-groups{display:flex;flex-direction:column;gap:1.75rem}
.sg{display:flex;flex-direction:column;gap:.6rem}
.sg-label{font-family:var(--mono);font-size:.65rem;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.1em}
.sg-chips{display:flex;flex-wrap:wrap;gap:.35rem}
.sc{padding:.22rem .6rem;border-radius:99px;font-size:.72rem;font-weight:500;background:var(--b3);border:1px solid rgba(238,244,241,.06);color:var(--t2);transition:background var(--dur),color var(--dur)}
.sc:hover{background:var(--b1);color:var(--t1)}
.sc-hi{background:rgba(139,184,88,.07);border-color:rgba(139,184,88,.18);color:#a8c87a}
.sc-ai{background:rgba(139,184,88,.05);border-color:rgba(139,184,88,.14);color:#a8c87a;animation:aiPulse 3.5s ease-in-out infinite}
@keyframes aiPulse{0%,100%{border-color:rgba(139,184,88,.14)}50%{border-color:rgba(139,184,88,.35)}}

/* ─── CONTACT (mobile-first) ─────────────────────────────────────── */
.contact-wrap{text-align:center}
.contact-sub{font-size:.88rem;color:var(--t2);margin-bottom:1.75rem}
.contact-btns{display:flex;gap:.6rem;justify-content:center;flex-wrap:wrap;margin-bottom:1rem}
.contact-info{font-size:.78rem;color:var(--t3)}

/* ─── FOOTER ─────────────────────────────────────────────────────── */
footer{padding:1.25rem 1.25rem;border-top:1px solid var(--b3);position:relative;z-index:1}
.footer-row{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.5rem}
.footer-mark{font-size:.8rem;font-weight:600;color:var(--t3)}
.footer-copy{font-size:.72rem;color:var(--t3)}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE — SCALE UP (min-width breakpoints, mobile-first)
   ═══════════════════════════════════════════════════════════════════ */

/* ─── SM (≥ 640px) ─── */
@media(min-width:640px){
  .nav-inner{padding:0 1.5rem}
  .nav-logo-img{width:50px;height:50px}

  #hero{padding:5.5rem 1.5rem 3.5rem}
  .hero-inner{gap:2.5rem}
  .hero-title{font-size:3.2rem}
  .hero-desc{font-size:.9rem}

  .hero-orb{width:180px;height:180px}
  .hero-orb-img{width:140px;height:140px;padding:14px}
  .orb-ring-1{inset:-25px}
  .orb-ring-2{inset:-52px}
  .orb-ring-3{inset:-78px}
  .hero-visual{min-height:280px}

  /* Show floating badges on sm+ */
  .hero-float{display:flex}
  .hf-num{font-size:1.2rem}
  .hf-text{font-size:.58rem}

  .section{padding:4rem 1.5rem}

  .about-meta{grid-template-columns:1fr 1fr}

  .pc-logo-banner{height:110px}
  .pc-body{padding:1.1rem 1.3rem 1.3rem}

  .footer-row{flex-direction:row;justify-content:space-between;text-align:left}
}

/* ─── MD (≥ 768px) ─── */
@media(min-width:768px){
  .nav-inner{padding:0 2rem}
  .nav-logo-img{width:56px;height:56px}

  /* Show desktop nav, hide hamburger */
  .nav-links{display:flex;margin-left:auto}
  .btn-nav{display:flex}
  .hamburger{display:none}

  #hero{padding:6rem 2rem 4rem}
  .hero-title{font-size:3.6rem}
  .hero-greeting{font-size:1rem}
  .hero-desc{font-size:.95rem}
  .hero-badge{font-size:.7rem}

  .hero-orb{width:220px;height:220px}
  .hero-orb-img{width:170px;height:170px;padding:14px}
  .orb-ring-1{inset:-28px}
  .orb-ring-2{inset:-56px}
  .orb-ring-3{inset:-84px}
  .hero-visual{min-height:340px}

  .section{padding:5rem 2rem}
  .sec-h{font-size:2rem;margin-bottom:2.5rem}
  .sec-h-xl{font-size:2.5rem}

  .about-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:3.5rem;align-items:start}
  .about-right p{font-size:.92rem}

  .exp-card{display:grid;grid-template-columns:150px 1fr;gap:2rem;padding:1.5rem}
  .exp-body li{font-size:.82rem}

  .pc-logo-banner{height:120px}
  .pc-body{gap:.6rem;padding:1.2rem 1.4rem 1.4rem}

  .skill-groups{display:grid;grid-template-columns:1fr 1fr;gap:2rem}

  footer{padding:1.25rem 2rem}
}

/* ─── LG (≥ 1024px) ─── */
@media(min-width:1024px){
  /* Hero: side-by-side layout */
  .hero-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:5rem;align-items:center;text-align:left}
  .hero-text{order:0}
  .hero-visual{order:1}
  .hero-badge{justify-content:flex-start}
  .hero-cta{justify-content:flex-start}
  .hero-links{align-items:flex-start}
  .hero-desc{margin-inline:0}

  .hero-title{font-size:clamp(3.5rem,5.5vw,5.2rem)}
  .hero-h1{margin-bottom:1.2rem}
  .hero-badge{margin-bottom:1.5rem}
  .hero-desc{margin-bottom:1.75rem}

  .hero-orb{width:260px;height:260px}
  .hero-orb-img{width:200px;height:200px;padding:16px}
  .orb-ring-1{inset:-30px}
  .orb-ring-2{inset:-60px}
  .orb-ring-3{inset:-90px}
  .hero-visual{min-height:380px}

  .hf-1{right:-15px}
  .hf-2{left:-25px}
  .hf-3{right:-35px}
  .hf-num{font-size:1.4rem}
  .hf-text{font-size:.62rem}

  .section{padding:6rem 2rem}
  .sec-h{font-size:clamp(1.8rem,3.5vw,2.5rem)}
  .sec-h-xl{font-size:clamp(2.2rem,4.5vw,3.2rem)}

  .about-grid{gap:4rem}

  .exp-card{grid-template-columns:160px 1fr;gap:2.5rem}

  /* Aurora blobs — full size on desktop */
  .aurora-blob-1{width:800px;height:800px}
  .aurora-blob-2{width:700px;height:700px}
  .aurora-blob-3{width:600px;height:600px}

  .btn-glow{padding:.58rem 1.35rem;font-size:.83rem}
  .btn-glass{padding:.58rem 1.35rem;font-size:.83rem}
}
