:root {
  --bg: #F5FAF8;
  --surface: #FFFFFF;
  --ink: #233D4D;
  --ink-2: #4A6572;
  --ink-3: #7A96A4;
  --accent: #FE7F2D;
  --accent-h: #E06520;
  --accent-lite: #FFF3E8;
  --accent-2: #619B8A;
  --accent-3: #FCCA46;
  --accent-4: #A1C181;
  --border: #D8E8E4;
  --sh-sm: 0 2px 8px rgba(0,0,0,0.06);
  --sh-md: 0 8px 32px rgba(0,0,0,0.10);
  --sh-lg: 0 24px 64px rgba(0,0,0,0.14);
  --r-sm: 8px; --r-md: 16px; --r-lg: 24px;
  --ease: cubic-bezier(0.4,0,0.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Poppins',sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden;cursor:none;line-height:1.6;}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;}
button{font-family:'Poppins',sans-serif;}
input,textarea,button,a,select{cursor:none;}

/* PROGRESS BAR */
#prog{position:fixed;top:0;left:0;height:3px;width:0%;background:var(--accent);z-index:10001;transition:width 0.05s;}

/* CURSOR */
#cdot{width:8px;height:8px;background:var(--accent);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:background .2s;}
#cring{width:36px;height:36px;border:1.5px solid var(--accent);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6;transition:width .3s,height .3s,background .3s,opacity .3s;}
#cring.hov{width:56px;height:56px;background:rgba(254,127,45,.08);opacity:1;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:22px 56px;display:flex;justify-content:space-between;align-items:center;transition:background .3s,backdrop-filter .3s,padding .3s;}
nav.scrolled{background:rgba(247,247,245,.9);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:14px 56px;border-bottom:1px solid var(--border);}
.nav-logo{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.3rem;letter-spacing:-.02em;}
.nav-logo span{color:var(--accent);}
.nav-links{display:flex;gap:36px;list-style:none;align-items:center;}
.nav-links a{font-size:.875rem;font-weight:500;color:var(--ink-2);transition:color .2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--accent);transition:width .3s var(--ease);}
.nav-links a:hover{color:var(--accent);}
.nav-links a:hover::after{width:100%;}
.nav-cta{background:var(--ink)!important;color:#fff!important;padding:10px 24px;border-radius:100px;font-weight:600!important;transition:background .2s,transform .2s!important;}
.nav-cta::after{display:none!important;}
.nav-cta:hover{background:var(--accent)!important;transform:translateY(-1px);}

/* HERO */
#hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:center;overflow:hidden;}
#hero-canvas{position:absolute;inset:0;z-index:0;}
.hero-content{position:relative;z-index:1;padding:0 56px;max-width:600px;}
.hero-visual-wrap{position:absolute;right:7%;top:50%;transform:translateY(-50%);z-index:1;}
.hero-visual{width:360px;height:360px;position:relative;animation:float-hero 4.5s ease-in-out infinite;}
@keyframes float-hero{0%,100%{transform:translateY(0);}50%{transform:translateY(-18px);}}
.hero-ring-outer{position:absolute;inset:-22px;border-radius:50%;background:conic-gradient(from 0deg,#FE7F2D,#FCCA46,#A1C181,#619B8A,#FE7F2D);animation:spin-ring 7s linear infinite;z-index:0;}
.hero-ring-outer::after{content:'';position:absolute;inset:7px;border-radius:50%;background:var(--bg);}
@keyframes spin-ring{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
.hero-orbit{position:absolute;inset:-52px;border-radius:50%;border:1.5px dashed rgba(254,127,45,.4);animation:spin-ring 20s linear infinite reverse;}
.hero-orbit-dot{position:absolute;width:12px;height:12px;background:linear-gradient(135deg,#FE7F2D,#619B8A);border-radius:50%;top:6px;left:50%;transform:translateX(-50%);box-shadow:0 0 18px rgba(254,127,45,.7);}
.hero-orbit-dot2{top:auto;bottom:6px;background:linear-gradient(135deg,#A1C181,#06B6D4);}
.hero-circle-img{width:100%;height:100%;border-radius:50%;object-fit:cover;position:relative;z-index:1;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--accent-lite);color:var(--accent);padding:8px 18px;border-radius:100px;font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:28px;opacity:0;transform:translateY(20px);}
.badge-dot{width:7px;height:7px;background:var(--accent-2);border-radius:50%;animation:blink 2s infinite;}
@keyframes blink{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(.8);}}
.hero-heading{font-size:clamp(2.6rem,5.5vw,5rem);font-weight:700;line-height:1.12;letter-spacing:-.025em;margin-bottom:22px;opacity:0;transform:translateY(30px);}
.hero-heading .ac{color:var(--accent);}
.hero-sub{font-size:clamp(.95rem,2.2vw,1.2rem);color:var(--ink-2);line-height:1.65;max-width:580px;margin-bottom:14px;opacity:0;transform:translateY(20px);}
.hero-role{color:var(--accent);font-weight:600;display:inline-block;transition:opacity .3s,transform .3s;}
.hero-tag{font-size:.875rem;color:var(--ink-3);font-style:italic;margin-bottom:40px;opacity:0;transform:translateY(20px);}
.hero-ctas{display:flex;gap:16px;align-items:center;opacity:0;transform:translateY(20px);}
.btn-p{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;padding:15px 32px;border-radius:100px;font-weight:600;font-size:.9rem;border:none;transition:background .2s,transform .2s,box-shadow .2s;}
.btn-p:hover{background:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(254,127,45,.35);}
.btn-s{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--ink);padding:15px 32px;border-radius:100px;font-weight:600;font-size:.9rem;border:1.5px solid var(--border);transition:border-color .2s,color .2s,transform .2s;}
.btn-s:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);}
.hero-scroll{position:absolute;bottom:32px;left:56px;display:flex;align-items:center;gap:12px;font-size:.78rem;color:var(--ink-3);opacity:0;}
.scroll-ln{width:40px;height:1px;background:var(--ink-3);overflow:hidden;position:relative;}
.scroll-ln::after{content:'';position:absolute;left:-100%;top:0;width:100%;height:100%;background:var(--accent);animation:sl 2s ease-in-out infinite;}
@keyframes sl{0%{left:-100%;}100%{left:100%;}}

/* REVEAL */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .75s var(--ease),transform .75s var(--ease);}
.reveal.vis{opacity:1;transform:translateY(0);}

/* SECTIONS */
section{padding:110px 56px;}
.sec-label{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.sec-h{font-size:clamp(1.75rem,3vw,2.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:18px;}
.sec-sub{font-size:1.05rem;color:var(--ink-2);max-width:580px;line-height:1.75;margin-bottom:60px;}

/* ABOUT */
#about{background:linear-gradient(145deg,#ffffff 0%,#FFF4E8 55%,#EEF7F5 100%);}
.about-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:80px;align-items:center;max-width:1200px;margin:0 auto;}
.about-img-wrap{position:relative;}
.about-img-bg{position:absolute;inset:-18px;border-radius:calc(var(--r-lg) + 18px);background:linear-gradient(135deg,rgba(254,127,45,.15),rgba(97,155,138,.1));z-index:0;}
.about-img{width:100%;max-width:400px;border-radius:var(--r-lg);object-fit:cover;aspect-ratio:4/5;position:relative;z-index:1;transition:transform .4s var(--ease),box-shadow .4s;}
.about-img:hover{transform:scale(1.03);box-shadow:0 24px 60px rgba(254,127,45,.25);}
.about-badge{position:absolute;bottom:28px;right:-20px;z-index:2;background:linear-gradient(135deg,#FE7F2D,#619B8A);color:#fff;border-radius:var(--r-md);padding:16px 22px;box-shadow:0 8px 32px rgba(254,127,45,.4);font-family:'Poppins',sans-serif;font-weight:800;font-size:1.6rem;white-space:nowrap;line-height:1;}
.about-badge small{display:block;font-family:'Poppins',sans-serif;font-weight:400;font-size:.72rem;color:rgba(255,255,255,.8);margin-top:4px;}
.about-text h2{font-size:clamp(1.6rem,2.8vw,2.4rem);font-weight:700;letter-spacing:-.02em;line-height:1.25;margin-bottom:22px;}
.about-text p{font-size:1rem;color:var(--ink-2);line-height:1.8;margin-bottom:18px;}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:36px;}
.stat{background:rgba(255,255,255,.8);border-radius:var(--r-md);padding:20px;text-align:center;border:1px solid rgba(254,127,45,.15);backdrop-filter:blur(8px);transition:transform .3s,box-shadow .3s;}
.stat:hover{transform:translateY(-4px);box-shadow:0 8px 28px rgba(254,127,45,.18);}
.stat-n{font-family:'Poppins',sans-serif;font-size:2rem;font-weight:800;background:linear-gradient(135deg,#FE7F2D,#A1C181);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:5px;}
.stat-l{font-size:.75rem;color:var(--ink-3);font-weight:500;}

/* SKILLS */
#skills{background:linear-gradient(180deg,#EEF7F5 0%,#E3F2EE 60%,#F2FAF7 100%);}
.skills-hd{max-width:1280px;margin:0 auto 40px;}
.skills-stats{display:flex;max-width:1280px;margin:0 auto 52px;background:rgba(255,255,255,.78);border-radius:var(--r-lg);border:1px solid var(--border);overflow:hidden;backdrop-filter:blur(14px);}
.skills-stat-item{flex:1;padding:24px 20px;text-align:center;border-right:1px solid var(--border);transition:background .25s;}
.skills-stat-item:last-child{border-right:none;}
.skills-stat-item:hover{background:rgba(254,127,45,.04);}
.skills-stat-n{display:block;font-size:1.85rem;font-weight:800;background:linear-gradient(135deg,#FE7F2D,#619B8A);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:5px;}
.skills-stat-l{font-size:.68rem;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;}
.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1280px;margin:0 auto;}
.sk-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--border);transition:transform .3s var(--ease),box-shadow .3s;position:relative;}
.sk-card:hover{box-shadow:0 20px 56px rgba(0,0,0,.11);}
.sk-accent{height:4px;width:100%;flex-shrink:0;}
.sk-card[data-accent="orange"] .sk-accent{background:linear-gradient(90deg,#FE7F2D,#FCCA46);}
.sk-card[data-accent="teal"]   .sk-accent{background:linear-gradient(90deg,#619B8A,#A1C181);}
.sk-card[data-accent="yellow"] .sk-accent{background:linear-gradient(90deg,#FCCA46,#A1C181);}
.sk-card[data-accent="navy"]   .sk-accent{background:linear-gradient(90deg,#233D4D,#619B8A);}
.sk-head{padding:20px 20px 14px;display:flex;align-items:flex-start;gap:14px;}
.sk-icon-bg{width:50px;height:50px;min-width:50px;border-radius:13px;display:grid;place-items:center;font-size:1.5rem;flex-shrink:0;transition:transform .35s var(--ease);}
.sk-card[data-accent="orange"] .sk-icon-bg{background:rgba(254,127,45,.1);}
.sk-card[data-accent="teal"]   .sk-icon-bg{background:rgba(97,155,138,.1);}
.sk-card[data-accent="yellow"] .sk-icon-bg{background:rgba(252,202,70,.14);}
.sk-card[data-accent="navy"]   .sk-icon-bg{background:rgba(35,61,77,.07);}
.sk-card:hover .sk-icon-bg{transform:scale(1.12) rotate(-6deg);}
.sk-meta{flex:1;min-width:0;}
.sk-meta h3{font-size:.92rem;font-weight:700;margin-bottom:5px;line-height:1.3;color:var(--ink);}
.sk-count{font-size:.67rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;}
.sk-card[data-accent="orange"] .sk-count{color:rgba(254,127,45,.85);}
.sk-card[data-accent="teal"]   .sk-count{color:rgba(97,155,138,.9);}
.sk-card[data-accent="yellow"] .sk-count{color:rgba(160,130,0,.8);}
.sk-card[data-accent="navy"]   .sk-count{color:rgba(35,61,77,.65);}
.sk-divider{height:1px;background:var(--border);margin:0 20px;}
.sk-body{padding:12px 20px 20px;}
.sk-tags{display:flex;flex-wrap:wrap;gap:6px;}
.sk-tag{font-size:.69rem;font-weight:500;padding:4px 10px;border-radius:100px;background:var(--bg);border:1px solid var(--border);color:var(--ink-2);transition:background .18s,color .18s,border-color .18s,transform .15s;}
.sk-card[data-accent="orange"]:hover .sk-tag{background:rgba(254,127,45,.08);border-color:rgba(254,127,45,.22);color:#C05800;}
.sk-card[data-accent="teal"]:hover   .sk-tag{background:rgba(97,155,138,.08);border-color:rgba(97,155,138,.24);color:#2E6B5C;}
.sk-card[data-accent="yellow"]:hover .sk-tag{background:rgba(252,202,70,.1);border-color:rgba(252,202,70,.3);color:#7A6200;}
.sk-card[data-accent="navy"]:hover   .sk-tag{background:rgba(35,61,77,.06);border-color:rgba(35,61,77,.18);color:#233D4D;}

/* PROJECTS */
#projects{background:linear-gradient(160deg,#ffffff 0%,#FFF8F0 40%,#EEF7F5 100%);}
.proj-hd{max-width:1280px;margin:0 auto 56px;}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1280px;margin:0 auto;}
.proj-card{background:rgba(255,255,255,.95);border-radius:var(--r-lg);overflow:hidden;border:1px solid rgba(254,127,45,.1);transform-style:preserve-3d;will-change:transform;transition:box-shadow .4s;}
.proj-card:hover{box-shadow:0 0 0 2px rgba(254,127,45,.45),0 24px 60px rgba(254,127,45,.22),0 8px 30px rgba(97,155,138,.1);}
.proj-img-wrap{overflow:hidden;position:relative;}
.proj-img{width:100%;aspect-ratio:16/9;object-fit:cover;object-position:top;transition:transform .6s var(--ease);}
.proj-card:hover .proj-img{transform:scale(1.05);}
.proj-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(0,0,0,.72));opacity:0;transition:opacity .35s;display:flex;align-items:flex-end;padding:18px;}
.proj-card:hover .proj-overlay{opacity:1;}
.proj-visit{display:inline-flex;align-items:center;gap:7px;background:#fff;color:var(--ink);padding:9px 18px;border-radius:100px;font-size:.78rem;font-weight:700;transition:background .2s,color .2s;}
.proj-visit:hover{background:var(--accent);color:#fff;}
.proj-body{padding:24px;}
.proj-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px;}
.proj-chip{font-size:.68rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 10px;border-radius:100px;background:linear-gradient(135deg,rgba(254,127,45,.12),rgba(97,155,138,.08));color:var(--accent);border:1px solid rgba(254,127,45,.15);}
.proj-card h3{font-size:1.1rem;font-weight:700;margin-bottom:9px;}
.proj-card p{font-size:.855rem;color:var(--ink-3);line-height:1.6;}

/* HOBBIES */
#hobbies{background:linear-gradient(145deg,#F5FAF8 0%,#EEF7F2 50%,#FFF8F0 100%);}
.hob-hd{max-width:1200px;margin:0 auto 52px;}
.hob-tabs{display:flex;gap:8px;max-width:1200px;margin:0 auto 36px;flex-wrap:wrap;}
.hob-tab{padding:11px 24px;border-radius:100px;font-size:.88rem;font-weight:600;border:1.5px solid rgba(254,127,45,.2);background:rgba(255,255,255,.7);color:var(--ink-2);transition:all .25s;font-family:'Poppins',sans-serif;backdrop-filter:blur(8px);}
.hob-tab.on,.hob-tab:hover{background:linear-gradient(135deg,#FE7F2D,#619B8A);color:#fff;border-color:transparent;box-shadow:0 6px 20px rgba(254,127,45,.35);}
.hob-panel{display:none;max-width:1200px;margin:0 auto;}
.hob-panel.on{display:block;}
.hob-layout{display:flex;flex-direction:column;gap:40px;}
.hob-text-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.hob-text h3{font-family:'Poppins',sans-serif;font-size:clamp(1.5rem,2.5vw,2.1rem);font-weight:700;letter-spacing:-.018em;line-height:1.3;margin-bottom:18px;}
.hob-text p{font-size:.97rem;color:var(--ink-2);line-height:1.75;margin-bottom:14px;}
.hob-quote-box{background:rgba(254,127,45,.06);border-left:3px solid var(--accent);padding:20px 24px;border-radius:0 var(--r-md) var(--r-md) 0;}
.hob-quote{font-size:.9rem;color:var(--ink-2);font-style:italic;line-height:1.7;}
.hob-gallery{display:grid;gap:16px;width:100%;}
.hob-gallery.g3{grid-template-columns:2fr 1fr;grid-template-rows:260px 260px;}
.hob-gallery.g3 .hob-card:first-child{grid-row:1/3;}
.hob-gallery.g4{grid-template-columns:repeat(4,1fr);grid-template-rows:300px;}
.hob-card{border-radius:var(--r-lg);overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.18);transition:transform .4s var(--ease),box-shadow .4s;cursor:none;position:relative;}
.hob-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 50%,rgba(0,0,0,.35));opacity:0;transition:opacity .4s;}
.hob-card:hover::after{opacity:1;}
.hob-card:hover{transform:perspective(900px) rotateY(-7deg) rotateX(4deg) scale(1.03);box-shadow:0 28px 70px rgba(0,0,0,.28);}
.hob-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);display:block;}
.hob-card:hover img{transform:scale(1.09);}

/* CONTACT */
#contact{background:linear-gradient(145deg,#EEF7F5 0%,#F5FAF8 50%,#ffffff 100%);}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:start;max-width:1100px;margin:0 auto;}
.contact-text h2{font-size:clamp(1.75rem,3vw,2.6rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;margin-bottom:18px;}
.contact-text p{font-size:1rem;color:var(--ink-2);line-height:1.75;margin-bottom:36px;}
.contact-socials{display:flex;gap:20px;margin-top:8px;}
.cs-btn{position:relative;display:flex;flex-direction:column;align-items:center;gap:10px;width:96px;padding:22px 0 18px;border-radius:20px;border:none;backdrop-filter:blur(12px);text-decoration:none;color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;overflow:hidden;transition:transform .35s var(--ease),box-shadow .35s,filter .35s;}
.cs-btn svg{width:28px;height:28px;transition:transform .4s var(--ease);}
.cs-ring{position:absolute;inset:-40%;border-radius:50%;opacity:0;transform:scale(.4);transition:opacity .45s,transform .45s var(--ease);pointer-events:none;}
.cs-email{background:linear-gradient(135deg,#FE7F2D,#FCCA46);box-shadow:0 8px 24px rgba(254,127,45,.35);}
.cs-linkedin{background:linear-gradient(135deg,#0A66C2,#2196f3);box-shadow:0 8px 24px rgba(10,102,194,.35);}
.cs-facebook{background:linear-gradient(135deg,#1877F2,#64b5f6);box-shadow:0 8px 24px rgba(24,119,242,.35);}
.cs-btn:hover{transform:translateY(-6px) scale(1.06);filter:brightness(1.15) saturate(1.2);box-shadow:0 20px 48px rgba(0,0,0,.22);}
.cs-btn:hover .cs-ring{opacity:.25;transform:scale(1);}
.cs-btn:hover svg{transform:scale(1.15) rotate(-8deg);}
.cs-email .cs-ring{background:radial-gradient(circle,#fff 0%,transparent 70%);}
.cs-linkedin .cs-ring{background:radial-gradient(circle,#fff 0%,transparent 70%);}
.cs-facebook .cs-ring{background:radial-gradient(circle,#fff 0%,transparent 70%);}
.c-icon{display:none;}
.c-form{display:flex;flex-direction:column;gap:18px;}
.f-group{display:flex;flex-direction:column;gap:7px;}
.f-group label{font-size:.82rem;font-weight:600;color:var(--ink-2);}
.f-group input,.f-group textarea{padding:13px 16px;border-radius:var(--r-sm);border:1.5px solid rgba(254,127,45,.15);background:rgba(255,255,255,.8);backdrop-filter:blur(8px);font-family:'Poppins',sans-serif;font-size:.9rem;color:var(--ink);outline:none;resize:vertical;transition:border-color .2s,background .2s,box-shadow .2s;}
.f-group input:focus,.f-group textarea:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px rgba(254,127,45,.08);}
.f-group textarea{min-height:130px;}
.f-submit{display:inline-flex;align-items:center;gap:9px;background:linear-gradient(135deg,#FE7F2D,#619B8A);color:#fff;padding:14px 34px;border-radius:100px;font-weight:600;font-size:.9rem;border:none;align-self:flex-start;transition:transform .2s,box-shadow .2s;}
.f-submit:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(254,127,45,.4);}

/* GRADIENT TEXT UTILITY */
.gt{background:linear-gradient(125deg,#FE7F2D 0%,#619B8A 50%,#A1C181 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

/* FOOTER */
footer{background:var(--ink);color:#fff;padding:36px 56px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.foot-logo{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.2rem;}
.foot-logo span{color:var(--accent-2);}
.foot-copy{font-size:.8rem;color:rgba(255,255,255,.45);}
.foot-copy em{color:rgba(255,255,255,.7);font-style:normal;}

/* SECTION ANIMATIONS */
#about,#skills,#projects,#hobbies,#contact{position:relative;overflow:hidden;}
#about .about-grid,#skills .skills-hd,#skills .skills-grid,
#projects .proj-hd,#projects .proj-grid,#hobbies .hob-hd,
#hobbies .hob-tabs,#hobbies .hob-panel,#contact .contact-grid,
#about>*:not(canvas):not(.sec-blob),
#skills>*:not(canvas):not(.sec-blob),
#projects>*:not(canvas):not(.sec-blob),
#hobbies>*:not(canvas):not(.sec-blob),
#contact>*:not(canvas):not(.sec-blob){position:relative;z-index:1;}

@keyframes blob-float{
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(30px,-22px) scale(1.06);}
  66%{transform:translate(-22px,18px) scale(0.95);}
}
.sec-blob{
  position:absolute;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0;
  animation:blob-float 14s ease-in-out infinite;
}

@keyframes fdot{
  0%{transform:translateY(0) scale(1);opacity:.8;}
  100%{transform:translateY(-100px) scale(.2);opacity:0;}
}
.f-dot{position:absolute;border-radius:50%;pointer-events:none;z-index:0;animation:fdot linear infinite;}

@keyframes icon-pop{0%,100%{transform:scale(1) translateY(0);}50%{transform:scale(1.25) translateY(-4px);}}

@keyframes shimmer{0%{transform:translateX(-160%)skewX(-12deg);}100%{transform:translateX(260%)skewX(-12deg);}}
.proj-img-wrap::before{
  content:'';position:absolute;top:0;left:0;width:45%;height:100%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.5),transparent);
  transform:translateX(-160%)skewX(-12deg);z-index:2;pointer-events:none;
}
.proj-card:hover .proj-img-wrap::before{animation:shimmer .75s ease .05s forwards;}

@keyframes pulse-ring{0%{transform:scale(1);opacity:.6;}70%{transform:scale(1.6);opacity:0;}100%{transform:scale(1.6);opacity:0;}}
.stat:hover .stat-n{color:var(--accent);transition:color .3s;}

@keyframes line-grow{from{transform:scaleX(0);}to{transform:scaleX(1);}}
.sec-label{position:relative;}
.sec-label::after{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:2px;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);}
.reveal.vis .sec-label::after,.sec-label.vis::after{transform:scaleX(1);}

/* LIGHTBOX */
#lightbox{display:none;position:fixed;inset:0;z-index:9990;align-items:center;justify-content:center;}
#lightbox.open{display:flex;}
#lb-overlay{position:absolute;inset:0;background:rgba(10,14,20,.92);}
#lightbox.open #lb-overlay{animation:lb-fade .25s ease forwards;}
@keyframes lb-fade{from{opacity:0;}to{opacity:1;}}
#lb-wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:12px;}
#lightbox.open #lb-wrap{animation:lb-scale .32s cubic-bezier(.23,1,.32,1) forwards;}
@keyframes lb-scale{from{transform:scale(.88);opacity:0;}to{transform:scale(1);opacity:1;}}
#lb-img{max-width:88vw;max-height:82vh;border-radius:10px;object-fit:contain;box-shadow:0 32px 80px rgba(0,0,0,.65);display:block;}
#lb-counter{font-size:.72rem;color:rgba(255,255,255,.42);font-family:'Poppins',sans-serif;letter-spacing:.1em;}
#lb-close{position:fixed;top:20px;right:24px;z-index:9995;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.8);width:44px;height:44px;border-radius:50%;font-size:1.5rem;line-height:1;display:grid;place-items:center;transition:background .2s,transform .2s;}
#lb-close:hover{background:var(--accent);color:#fff;transform:scale(1.12);}
#lb-prev,#lb-next{position:fixed;top:50%;z-index:9995;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.8);width:48px;height:48px;border-radius:50%;font-size:1.2rem;display:grid;place-items:center;transition:background .2s,transform .2s;}
#lb-prev{left:20px;transform:translateY(-50%);}
#lb-next{right:20px;transform:translateY(-50%);}
#lb-prev:hover{background:var(--accent);color:#fff;transform:translateY(-50%) scale(1.1);}
#lb-next:hover{background:var(--accent);color:#fff;transform:translateY(-50%) scale(1.1);}
.proj-zoom{background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.28);color:#fff;padding:8px 16px;border-radius:100px;font-size:.75rem;font-weight:600;font-family:'Poppins',sans-serif;display:inline-flex;align-items:center;gap:6px;margin-left:8px;transition:background .2s;}
.proj-zoom:hover{background:rgba(255,255,255,.28);}
.hob-card::before{content:'';position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;z-index:4;opacity:0;transition:opacity .3s;pointer-events:none;background:rgba(255,255,255,.88) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23233D4D' stroke-width='2.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") center/14px no-repeat;}
.hob-card:hover::before{opacity:1;}

/* RESPONSIVE */
@media(max-width:1100px){
  .proj-grid{grid-template-columns:repeat(2,1fr);}
  .skills-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:1100px){.hero-visual-wrap{right:2%;} .hero-visual{width:300px;height:300px;}}
@media(max-width:900px){
  section{padding:80px 32px;}
  nav,nav.scrolled{padding:14px 32px;}
  .hero-content{padding:0 32px;max-width:100%;}
  .hero-scroll{left:32px;}
  .hero-visual-wrap{display:none;}
  .about-grid{grid-template-columns:1fr;gap:48px;}
  .about-img-wrap{max-width:380px;margin:0 auto;}
  .about-badge{right:0;}
  .contact-grid{grid-template-columns:1fr;}
  .hob-text-row{grid-template-columns:1fr;}
  .hob-gallery.g3{grid-template-columns:1fr 1fr;grid-template-rows:220px 220px;}
  .hob-gallery.g3 .hob-card:first-child{grid-row:auto;}
  .hob-gallery.g4{grid-template-columns:1fr 1fr;grid-template-rows:200px 200px;}
}
@media(max-width:680px){
  section{padding:64px 20px;}
  nav,nav.scrolled{padding:12px 20px;}
  .nav-links li:not(:last-child){display:none;}
  .hero-content{padding:0 20px;}
  .hero-ctas{flex-direction:column;align-items:flex-start;}
  .proj-grid{grid-template-columns:1fr;}
  .skills-grid{grid-template-columns:1fr 1fr;}
  .skills-stats{flex-wrap:wrap;}
  .skills-stat-item{flex:1 1 45%;border-right:none;border-bottom:1px solid var(--border);padding:16px 12px;}
  .skills-stat-item:nth-child(odd){border-right:1px solid var(--border);}
  .skills-stat-item:last-child,.skills-stat-item:nth-last-child(2):nth-child(odd){border-bottom:none;}
  .hob-photos{grid-template-columns:1fr;}
  footer{padding:28px 20px;}
  .hero-scroll{left:20px;}
  .about-stats{grid-template-columns:repeat(3,1fr);gap:10px;}
}
@media(max-width:420px){
  .skills-grid{grid-template-columns:1fr;}
  .about-stats{grid-template-columns:1fr 1fr;}
}
