:root {
  --bg-primary: #0f0f0f; --bg-secondary: #161616; --bg-card: #1a1a1a;
  --bg-card-hover: #222222; --surface: #252525;
  --text-primary: #e8e4e0; --text-secondary: #a09a94; --text-tertiary: #6b6560;
  --accent: #b8a088; --accent-light: #d4c4b0; --accent-dim: #8a7868;
  --border: #2a2a2a; --border-light: #333333;
  --radius-sm: 6px; --radius-md: 12px; --radius-xl: 32px;
  --transition-fast: 0.2s cubic-bezier(0.4,0,0.2,1);
  --transition-base: 0.35s cubic-bezier(0.4,0,0.2,1);
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-serif: 'Playfair Display', Georgia, serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.section{padding:120px 0;position:relative;opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.section.section-visible{opacity:1;transform:translateY(0)}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 24px;transition:var(--transition-base);background:transparent}
.nav.scrolled{background:rgba(15,15,15,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.nav-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-logo{font-family:var(--font-serif);font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:2px;transition:var(--transition-fast)}
.nav-logo:hover{color:var(--accent)}
.nav-links{display:flex;gap:36px}
.nav-link{font-size:.85rem;color:var(--text-secondary);letter-spacing:.5px;text-transform:uppercase;position:relative;transition:var(--transition-fast)}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--accent);transition:var(--transition-base)}
.nav-link:hover{color:var(--text-primary)}
.nav-link:hover::after{width:100%}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.nav-toggle span{display:block;width:24px;height:1.5px;background:var(--text-primary);transition:var(--transition-fast)}
.mobile-nav{position:fixed;inset:0;z-index:99;background:rgba(15,15,15,.97);backdrop-filter:blur(30px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;opacity:0;pointer-events:none;transition:var(--transition-base)}
.mobile-nav.open{opacity:1;pointer-events:all}
.mobile-nav-link{font-family:var(--font-serif);font-size:2rem;color:var(--text-secondary);transition:var(--transition-fast)}
.mobile-nav-link:hover{color:var(--text-primary)}

/* Hero */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;overflow:hidden;padding:120px 24px 80px}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:60px 60px;opacity:.3;mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 70% 60% at 50% 50%,black 20%,transparent 70%)}
.hero-content{position:relative;z-index:2}
/* Profile Photo */
.profile-photo{position:relative;width:150px;height:150px;margin:0 auto 32px;opacity:0;animation:fadeUp .8s ease forwards .1s}
.profile-img{width:100%;height:100%;object-fit:cover;object-position:center center;border-radius:50%;position:relative;z-index:2;border:3px solid var(--border-light);transition:all .5s ease}
.profile-img:hover{border-color:var(--accent);transform:scale(1.05);box-shadow:0 0 40px rgba(184,160,136,.25)}
.profile-ring{position:absolute;inset:-6px;border-radius:50%;border:1.5px solid transparent;border-top-color:var(--accent);border-right-color:var(--accent-dim);animation:ringRotate 4s linear infinite;z-index:1}
.profile-ring::after{content:'';position:absolute;inset:3px;border-radius:50%;border:1px solid transparent;border-bottom-color:var(--accent-dim);border-left-color:var(--accent);animation:ringRotate 3s linear infinite reverse}
@keyframes ringRotate{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.hero-label{font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:4px;color:var(--accent);margin-bottom:28px;opacity:0;animation:fadeUp .8s ease forwards .2s}
.hero-title{font-family:var(--font-serif);line-height:1.1;margin-bottom:24px}
.hero-title-line{display:block;font-size:clamp(2.5rem,7vw,5.5rem);font-weight:400;opacity:0;animation:fadeUp .8s ease forwards .4s}
.hero-title-accent{font-style:italic;color:var(--accent-light);opacity:0;animation:fadeUp .8s ease forwards .6s}
.hero-subtitle{font-size:1rem;color:var(--text-secondary);letter-spacing:6px;text-transform:uppercase;margin-bottom:48px;opacity:0;animation:fadeUp .8s ease forwards .8s}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .8s ease forwards 1s}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;opacity:0;animation:fadeUp .8s ease forwards 1.4s}
.hero-scroll span{font-size:.65rem;text-transform:uppercase;letter-spacing:3px;color:var(--text-tertiary)}
.hero-scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--accent-dim),transparent);animation:scrollPulse 2s ease-in-out infinite}

/* Buttons */
.btn{display:inline-flex;align-items:center;padding:14px 36px;font-family:var(--font-sans);font-size:.85rem;font-weight:500;letter-spacing:1px;text-transform:uppercase;border-radius:var(--radius-xl);cursor:pointer;transition:all .4s ease;border:none}
.btn-primary{background:var(--accent);color:var(--bg-primary)}
.btn-primary:hover{background:var(--accent-light);transform:translateY(-3px);box-shadow:0 12px 40px rgba(184,160,136,.25)}
.btn-outline{background:transparent;color:var(--text-secondary);border:1px solid var(--border-light)}
.btn-outline:hover{border-color:var(--accent-dim);color:var(--text-primary);transform:translateY(-3px)}

/* Section Header */
.section-header{display:flex;align-items:center;gap:20px;margin-bottom:64px}
.section-tag{font-size:.75rem;font-weight:500;color:var(--accent);letter-spacing:2px;padding:6px 14px;border:1px solid var(--border-light);border-radius:var(--radius-xl)}
.section-title{font-family:var(--font-serif);font-size:clamp(2rem,4vw,3rem);font-weight:400}

/* About */
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:start}
.about-lead{font-size:1.35rem;line-height:1.8;margin-bottom:20px}
.about-lead strong{color:var(--accent-light);font-weight:600}
.about-body{font-size:1rem;color:var(--text-secondary);line-height:1.9}
.detail-card{padding:28px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:20px;transition:all .4s ease}
.detail-card:hover{border-color:var(--border-light);background:var(--bg-card-hover);transform:translateY(-3px)}
.detail-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:3px;color:var(--accent);margin-bottom:20px}
.detail-item{display:flex;flex-direction:column;margin-bottom:16px}
.detail-item:last-child{margin-bottom:0}
.detail-year{font-size:.75rem;color:var(--text-tertiary);letter-spacing:1px;margin-bottom:2px}
.detail-name{font-size:1rem;font-weight:500}
.detail-desc{font-size:.85rem;color:var(--text-secondary)}
.lang-tags{display:flex;gap:10px}
.lang-tag{padding:8px 20px;background:var(--surface);border-radius:var(--radius-xl);font-size:.85rem;color:var(--text-secondary);border:1px solid var(--border);transition:var(--transition-fast)}
.lang-tag:hover{border-color:var(--accent-dim);color:var(--text-primary)}

/* Experience */
.experience{background:var(--bg-secondary)}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.exp-card{padding:32px 28px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .4s ease;position:relative;overflow:hidden}
.exp-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--accent-dim),transparent);opacity:0;transition:var(--transition-base)}
.exp-card:hover{border-color:var(--border-light);background:var(--bg-card-hover);transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.3)}
.exp-card:hover::before{opacity:1}
.exp-card-highlight{border-color:var(--accent-dim);background:linear-gradient(135deg,var(--bg-card),rgba(184,160,136,.06))}
.exp-badge{position:absolute;top:16px;right:16px;font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:2px;color:var(--accent);padding:4px 12px;border:1px solid var(--accent-dim);border-radius:var(--radius-xl)}
.exp-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);background:var(--surface);color:var(--accent);margin-bottom:20px;transition:all .4s ease}
.exp-card:hover .exp-icon{background:var(--accent-dim);color:var(--bg-primary);transform:scale(1.1)}
.exp-title{font-family:var(--font-serif);font-size:1.15rem;font-weight:500;margin-bottom:10px}
.exp-desc{font-size:.9rem;color:var(--text-secondary);line-height:1.7}

/* Skills */
.skills-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px}
.skill-group-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:3px;color:var(--accent);margin-bottom:28px}
.skill-items{display:flex;flex-direction:column;gap:20px}
.skill-item{display:flex;flex-direction:column;gap:8px}
.skill-name{font-size:.9rem;font-weight:400}
.skill-bar{width:100%;height:3px;background:var(--border);border-radius:100px;overflow:hidden}
.skill-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent-dim),var(--accent));border-radius:100px;transition:width 1.2s ease}
.skill-fill.animated{width:var(--fill)}
.soft-skills{display:flex;flex-direction:column;gap:16px}
.soft-skill{display:flex;align-items:center;gap:16px;padding:18px 22px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .4s ease}
.soft-skill:hover{border-color:var(--border-light);background:var(--bg-card-hover);transform:translateX(8px)}
.soft-skill-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:var(--radius-sm);color:var(--accent);flex-shrink:0}
.soft-skill span{font-size:.95rem;color:var(--text-secondary)}
.soft-skill:hover span{color:var(--text-primary)}

/* Contact */
.contact{background:var(--bg-secondary)}
.contact-lead{font-family:var(--font-serif);font-size:1.6rem;margin-bottom:48px;font-weight:400}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.contact-grid-4{grid-template-columns:repeat(2,1fr)}
.contact-card{padding:32px 28px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;flex-direction:column;transition:all .4s ease;cursor:default}
a.contact-card{cursor:pointer}
.contact-card:hover{border-color:var(--border-light);background:var(--bg-card-hover);transform:translateY(-6px);box-shadow:0 16px 48px rgba(0,0,0,.3)}
.contact-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface);border-radius:var(--radius-sm);color:var(--accent);margin-bottom:20px;transition:all .4s ease}
.contact-card:hover .contact-icon{background:var(--accent-dim);color:var(--bg-primary);transform:scale(1.1)}
.contact-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:3px;color:var(--accent);margin-bottom:8px}
.contact-value{font-size:.95rem;color:var(--text-secondary);word-break:break-all}

/* Footer */
.footer{padding:32px 0;border-top:1px solid var(--border)}
.footer-inner{display:flex;align-items:center;justify-content:space-between}
.footer-logo{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;letter-spacing:2px;color:var(--text-tertiary)}
.footer-copy{font-size:.8rem;color:var(--text-tertiary)}

/* ========== KITTEN PET ========== */
.kitten{position:fixed;bottom:20px;left:60px;z-index:90;cursor:pointer;user-select:none}
.kitten-inner{position:relative;transition:transform .15s ease}
.kitten.face-left .kitten-inner{transform:scaleX(-1)}
.kitten-body{position:relative;width:80px;height:75px}

.ear{position:absolute;top:0;width:20px;height:24px;background:#9a8878;border-radius:50% 50% 10% 10%;z-index:1;transition:transform .3s ease}
.ear::after{content:'';position:absolute;top:5px;left:50%;transform:translateX(-50%);width:12px;height:15px;background:#c8a890;border-radius:50% 50% 10% 10%}
.ear-left{left:10px;transform:rotate(-12deg)}
.ear-right{right:10px;transform:rotate(12deg)}
.kitten:hover .ear-left,.kitten.happy .ear-left{transform:rotate(-4deg) translateY(-3px)}
.kitten:hover .ear-right,.kitten.happy .ear-right{transform:rotate(4deg) translateY(-3px)}
.kitten.alert .ear-left{transform:rotate(-20deg)}
.kitten.alert .ear-right{transform:rotate(20deg)}

.kitten-head{position:absolute;top:12px;left:50%;transform:translateX(-50%);width:56px;height:46px;background:#a89888;border-radius:50% 50% 42% 42%;z-index:2}
.kitten-face{position:relative;width:100%;height:100%}
.eye{position:absolute;top:16px;width:13px;height:13px;background:#1c1c1c;border-radius:50%;overflow:hidden;transition:all .15s ease}
.eye-left{left:11px}.eye-right{right:11px}
.pupil{position:absolute;width:7px;height:7px;background:#f0ece8;border-radius:50%;top:3px;left:3px;transition:all .08s ease}
.pupil::after{content:'';position:absolute;width:3px;height:3px;background:#fff;border-radius:50%;top:0;left:1px}
.kitten.blink .eye{height:2px;top:22px}
.kitten.happy .eye{height:5px;top:20px;border-radius:50% 50% 0 0}
.kitten.sleeping .eye{height:2px;top:22px}
.kitten.surprised .eye{width:16px;height:16px;top:14px}

.cheek{position:absolute;top:26px;width:10px;height:6px;background:rgba(220,160,140,0);border-radius:50%;transition:background .3s}
.cheek-left{left:4px}.cheek-right{right:4px}
.kitten.happy .cheek,.kitten:hover .cheek{background:rgba(220,160,140,.5)}

.nose{position:absolute;bottom:13px;left:50%;transform:translateX(-50%);width:7px;height:5px;background:#d4a8a0;border-radius:50% 50% 40% 40%;z-index:1}
.mouth{position:absolute;bottom:7px;left:50%;transform:translateX(-50%);width:14px;height:6px;border-bottom:2px solid #7a6b60;border-radius:0 0 50% 50%;transition:all .3s}
.kitten.happy .mouth{width:18px;height:8px}
.kitten.meowing .mouth{width:10px;height:10px;background:#4a3a30;border:none;border-radius:50%;bottom:4px}

.whisker{position:absolute;width:22px;height:1px;background:rgba(160,154,148,.7);transition:all .3s}
.wh-lt{top:28px;left:-8px;transform:rotate(-8deg)}
.wh-lb{top:33px;left:-7px;transform:rotate(6deg)}
.wh-rt{top:28px;right:-8px;transform:rotate(8deg)}
.wh-rb{top:33px;right:-7px;transform:rotate(-6deg)}
.kitten:hover .wh-lt,.kitten.happy .wh-lt{transform:rotate(-18deg) translateX(-2px)}
.kitten:hover .wh-lb,.kitten.happy .wh-lb{transform:rotate(14deg) translateX(-2px)}
.kitten:hover .wh-rt,.kitten.happy .wh-rt{transform:rotate(18deg) translateX(2px)}
.kitten:hover .wh-rb,.kitten.happy .wh-rb{transform:rotate(-14deg) translateX(2px)}

.kitten-torso{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);width:48px;height:32px;background:#9a8878;border-radius:50% 50% 38% 38%;z-index:1;overflow:hidden}
.belly-stripe{position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:24px;height:16px;background:#baa898;border-radius:50% 50% 0 0}

.leg{position:absolute;bottom:0;width:12px;height:16px;background:#8a7868;border-radius:4px 4px 6px 6px;z-index:3;transform-origin:top center;transition:transform .15s}
.leg::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:14px;height:6px;background:#d4b8a8;border-radius:50%}
.leg-fl{left:16px}.leg-fr{left:24px}.leg-bl{right:16px}.leg-br{right:24px}

.kitten.walking .leg-fl{animation:legF .35s ease-in-out infinite}
.kitten.walking .leg-fr{animation:legF .35s ease-in-out infinite .175s}
.kitten.walking .leg-bl{animation:legB .35s ease-in-out infinite .175s}
.kitten.walking .leg-br{animation:legB .35s ease-in-out infinite}
.kitten.walking .kitten-body{animation:wBounce .35s ease-in-out infinite}
.kitten.running .leg-fl{animation:legF .18s ease-in-out infinite}
.kitten.running .leg-fr{animation:legF .18s ease-in-out infinite .09s}
.kitten.running .leg-bl{animation:legB .18s ease-in-out infinite .09s}
.kitten.running .leg-br{animation:legB .18s ease-in-out infinite}
.kitten.running .kitten-body{animation:wBounce .18s ease-in-out infinite}
@keyframes legF{0%,100%{transform:rotate(15deg)}50%{transform:rotate(-15deg)}}
@keyframes legB{0%,100%{transform:rotate(-12deg)}50%{transform:rotate(12deg)}}
@keyframes wBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}

.kitten.sitting .leg-bl{height:10px;transform:rotate(20deg)}
.kitten.sitting .leg-br{height:10px;transform:rotate(-20deg)}
.kitten.sitting .kitten-torso{bottom:4px}
.kitten.grooming .leg-fl{transform:rotate(-40deg) translateY(-8px)}
.kitten.grooming .kitten-head{transform:translateX(-50%) rotate(-15deg) translateX(-4px)}
.kitten.stretching .leg-fl,.kitten.stretching .leg-fr{transform:rotate(-25deg)}
.kitten.stretching .kitten-torso{transform:translateX(-50%) scaleX(1.15)}
.kitten.jumping .kitten-inner{animation:kJump .6s ease}
.kitten.jumping.face-left .kitten-inner{animation:kJumpF .6s ease}
@keyframes kJump{0%{transform:translateY(0)}40%{transform:translateY(-35px)}100%{transform:translateY(0)}}
@keyframes kJumpF{0%{transform:scaleX(-1) translateY(0)}40%{transform:scaleX(-1) translateY(-35px)}100%{transform:scaleX(-1) translateY(0)}}
.kitten.pouncing .kitten-inner{animation:pounce .5s ease}
@keyframes pounce{0%{transform:translateY(0) scaleY(.8) scaleX(1.1)}30%{transform:translateY(-20px) scaleY(1.1) scaleX(.95)}100%{transform:translateY(0)}}

.kitten-tail{position:absolute;bottom:14px;right:-8px;width:32px;height:8px;background:#8a7868;border-radius:0 50% 50% 0;transform-origin:left center;animation:tailW 2.5s ease-in-out infinite;z-index:0}
@keyframes tailW{0%,100%{transform:rotate(-8deg)}25%{transform:rotate(15deg)}75%{transform:rotate(-15deg)}}
.kitten.happy .kitten-tail{animation:tailH .4s ease-in-out infinite}
@keyframes tailH{0%,100%{transform:rotate(-20deg)}50%{transform:rotate(25deg)}}
.kitten.sleeping .kitten-tail{animation:tailS 5s ease-in-out infinite}
@keyframes tailS{0%,100%{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}

.kitten-shadow{width:55px;height:8px;background:radial-gradient(ellipse,rgba(0,0,0,.25),transparent 70%);margin:0 auto;transition:all .3s}
.kitten.jumping .kitten-shadow{transform:scaleX(.6);opacity:.3}
.kitten.purring .kitten-body{animation:purr .08s linear infinite alternate}
@keyframes purr{from{transform:translateX(-.4px)}to{transform:translateX(.4px)}}

.kitten-effects{position:absolute;top:-10px;left:50%;transform:translateX(-50%);pointer-events:none;width:60px;height:60px}
.heart-particle{position:absolute;opacity:0;animation:hFloat 1.4s ease-out forwards}
.heart-particle::before{content:'';display:block;width:10px;height:10px;background:#d4a8a0;transform:rotate(45deg);border-radius:50% 50% 0 50%}
@keyframes hFloat{0%{opacity:1;transform:translateY(0) scale(.4)}100%{opacity:0;transform:translateY(-55px) scale(1.1)}}
.sparkle{position:absolute;width:4px;height:4px;background:var(--accent-light);border-radius:50%;opacity:0;animation:spk .8s ease-out forwards}
@keyframes spk{0%{opacity:1;transform:scale(0)}50%{opacity:1;transform:scale(1.5)}100%{opacity:0;transform:scale(0)}}
.zzz-particle{position:absolute;font-family:var(--font-serif);font-style:italic;font-size:.65rem;color:var(--text-tertiary);opacity:0;animation:zF 3s ease-in-out infinite;right:-5px}
.zzz-particle:nth-child(2){font-size:.8rem;animation-delay:1s;right:0}
.zzz-particle:nth-child(3){font-size:.95rem;animation-delay:2s;right:5px}
@keyframes zF{0%{opacity:0;transform:translateY(0)}25%{opacity:.6}100%{opacity:0;transform:translateY(-35px) rotate(12deg)}}
.note-particle{position:absolute;font-size:.85rem;opacity:0;animation:nF 1.5s ease-out forwards;color:var(--accent);font-family:var(--font-serif)}
@keyframes nF{0%{opacity:1;transform:translateY(0)}100%{opacity:0;transform:translateY(-40px) translateX(var(--dx,10px))}}

.kitten-speech{position:absolute;top:-42px;left:50%;transform:translateX(-50%) scale(0);background:var(--bg-card);border:1px solid var(--border-light);color:var(--text-secondary);font-family:var(--font-sans);font-size:.7rem;padding:5px 11px;border-radius:var(--radius-xl);white-space:nowrap;opacity:0;transition:all .3s cubic-bezier(.68,-.55,.27,1.55);pointer-events:none;z-index:10}
.kitten-speech::after{content:'';position:absolute;bottom:-5px;left:50%;transform:translateX(-50%) rotate(45deg);width:7px;height:7px;background:var(--bg-card);border-right:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}
.kitten-speech.show{opacity:1;transform:translateX(-50%) scale(1)}

.yarn-ball{position:fixed;bottom:22px;width:18px;height:18px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#d4644a,#a83830);box-shadow:inset -2px -2px 4px rgba(0,0,0,.3),0 2px 4px rgba(0,0,0,.2);z-index:89;display:none}
.yarn-ball::before{content:'';position:absolute;top:3px;left:4px;width:10px;height:6px;border:1.5px solid rgba(255,255,255,.25);border-radius:50%;transform:rotate(-20deg)}
.yarn-ball.visible{display:block}
.yarn-ball.rolling{animation:roll .5s linear infinite}
@keyframes roll{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* Animations */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes scrollPulse{0%,100%{opacity:.3;transform:scaleY(1)}50%{opacity:.8;transform:scaleY(1.2)}}
[data-animate]{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
[data-animate].visible{opacity:1;transform:translateY(0)}

/* Entertainment / Mini-Craft */
.entertainment { background: var(--bg-primary); }
.mc-wrapper { display: flex; flex-direction: column; align-items: center; gap: 20px; background: var(--bg-card); padding: 30px; border-radius: var(--radius-md); border: 1px solid var(--border); }
#mc-canvas { display: block; background: #87CEEB; /* Sky blue */ border: 4px solid var(--border); box-shadow: inset 0 0 10px rgba(0,0,0,0.2); border-radius: 4px; cursor: crosshair; touch-action: none; max-width: 100%; height: auto; }
.mc-toolbar { display: flex; gap: 12px; width: 100%; max-width: 600px; padding: 12px; background: var(--bg-primary); border: 1px solid var(--border-light); border-radius: var(--radius-md); align-items: center; flex-wrap: wrap; }
.mc-tool { position: relative; width: 44px; height: 44px; background: var(--bg-secondary); border: 2px solid var(--border); border-radius: 4px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: all 0.2s ease; }
.mc-tool:hover { transform: translateY(-2px); border-color: var(--accent); }
.mc-tool.active { border-color: var(--accent); box-shadow: 0 0 8px rgba(197,160,112,0.6); }
.mc-block { width: 32px; height: 32px; border: 1px solid rgba(0,0,0,0.3); border-radius: 2px; }
.mc-grass { background: linear-gradient(180deg, #7CBA3D 0%, #7CBA3D 25%, #6E4933 25%, #6E4933 100%); }
.mc-dirt { background: #6E4933; }
.mc-stone { background: #888888; border-color: #666; }
.mc-wood { background: #5E4322; }
.mc-leaves { background: rgba(50, 160, 50, 0.9); }
.mc-eraser { font-weight: bold; color: var(--text-primary); font-size: 20px; font-family: monospace; }

@media(max-width:900px){
  .nav-links{display:none}.nav-toggle{display:flex}
  .about-grid{grid-template-columns:1fr;gap:40px}
  .exp-grid{grid-template-columns:repeat(2,1fr)}
  .skills-grid{grid-template-columns:1fr;gap:48px}
  .contact-grid,.contact-grid-4{grid-template-columns:1fr}
  .section{padding:80px 0}
  .kitten{transform:scale(.85)}
}
@media(max-width:600px){
  .exp-grid{grid-template-columns:1fr}
  .hero{padding:100px 20px 60px}
  .hero-subtitle{letter-spacing:3px;font-size:.85rem}
  .btn{padding:12px 28px;font-size:.8rem}
  .section-header{margin-bottom:40px}
  .footer-inner{flex-direction:column;gap:12px;text-align:center}
  .contact-lead{font-size:1.3rem}
  .kitten{transform:scale(.7)}
}

/* Preloader */
body.loading { overflow: hidden; }
.preloader { position: fixed; inset: 0; background: var(--bg-primary); z-index: 9999; display: flex; flex-direction: column; align-items: center; justify-content: center; transition: opacity 0.8s ease, visibility 0.8s ease; }
.preloader.hidden { opacity: 0; visibility: hidden; }
.loader-cat { position: relative; width: 50px; height: 50px; animation: loaderJump 0.6s cubic-bezier(0.5,0,0.5,1) infinite alternate; z-index: 2; }
.loader-cat-body { position: absolute; bottom: 0; left: 10px; width: 30px; height: 20px; background: var(--accent); border-radius: 15px; }
.loader-cat-head { position: absolute; bottom: 12px; left: 25px; width: 24px; height: 24px; background: var(--accent); border-radius: 50%; }
.loader-cat-ear { position: absolute; top: -4px; width: 0; height: 0; border-left: 6px solid transparent; border-right: 6px solid transparent; border-bottom: 10px solid var(--accent); }
.loader-cat-ear.l { left: -2px; transform: rotate(-15deg); }
.loader-cat-ear.r { right: -2px; transform: rotate(15deg); }
.loader-cat-tail { position: absolute; bottom: 5px; left: -2px; width: 17px; height: 6px; background: var(--accent); border-radius: 3px; transform-origin: right center; animation: loaderTail 0.6s ease-in-out infinite alternate; }
.loader-shadow { width: 40px; height: 6px; background: radial-gradient(ellipse, rgba(0,0,0,0.4) 0%, transparent 70%); margin-top: 5px; animation: loaderShadow 0.6s cubic-bezier(0.5,0,0.5,1) infinite alternate; }
.loader-text { margin-top: 30px; font-family: var(--font-serif); font-style: italic; font-size: 1.1rem; color: var(--accent); letter-spacing: 2px; animation: pulse 1s infinite alternate; }

@keyframes loaderJump {
  0% { transform: translateY(0) scaleY(0.85) scaleX(1.1); }
  100% { transform: translateY(-45px) scaleY(1.05) scaleX(0.95); }
}
@keyframes loaderShadow {
  0% { transform: scaleX(1); opacity: 1; }
  100% { transform: scaleX(0.5); opacity: 0.3; }
}
@keyframes loaderTail {
  0% { transform: rotate(20deg); }
  100% { transform: rotate(-30deg); }
}
@keyframes pulse {
  0% { opacity: 0.4; }
  100% { opacity: 1; }
}
