:root {
  --color-primary: #1A6B4C;
  --color-primary-dark: #0D3526;
  --color-primary-darker: #072014;
  --color-accent-gold: #C9A96E;
  --color-bg: #FBFDF8;
  --color-surface: #FFFFFF;
  --color-surface-variant: #E8F1EB;
  --color-text: #191C1A;
  --color-text-light: #414942;
  --font-heading: 'Playfair Display', serif;
  --font-body: 'Inter', sans-serif;
  --spacing-section: 120px;
  --spacing-section-mobile: 64px;
  --container-width: 1200px;
  --transition-smooth: cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased;will-change:auto}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
.container{max-width:var(--container-width);margin:0 auto;padding:0 24px}
@media(max-width:480px){.container{padding:0 16px}}
.section{padding:var(--spacing-section) 0;position:relative}
@media(max-width:768px){.section{padding:var(--spacing-section-mobile) 0}}
.section-label{font-family:var(--font-body);font-size:.875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent-gold);display:block;margin-bottom:12px}
.section-label--light{color:var(--color-accent-gold)}
.section-title{font-family:var(--font-heading);font-size:2.5rem;font-weight:600;line-height:1.2;color:var(--color-text);margin-bottom:20px}
@media(max-width:768px){.section-title{font-size:1.75rem}}
.accent-line{width:60px;height:3px;background:var(--color-primary);border-radius:100px;margin-bottom:24px}
.section-header-center{text-align:center;margin-bottom:48px}

/* === DESKTOP (>=769px) === */
@media(min-width:769px){
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;padding:12px 0;background:transparent;transition:background .4s var(--transition-smooth),box-shadow .4s var(--transition-smooth)}
.site-header.scrolled{background:rgba(255,255,255,.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 1px 3px rgba(0,0,0,.06)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.site-logo-text{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--color-primary);flex-shrink:0}
.logo-accent{color:var(--color-primary-dark)}
.desktop-navigation{flex:1;display:flex;justify-content:center}
.desktop-nav-menu{display:flex;gap:32px;align-items:center}
.desktop-nav-menu a{font-family:var(--font-body);font-size:.9375rem;font-weight:500;color:var(--color-text);position:relative;padding:4px 0;transition:color .3s}
.desktop-nav-menu a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--color-primary);transition:width .3s var(--transition-smooth)}
.desktop-nav-menu a:hover{color:var(--color-primary)}
.desktop-nav-menu a:hover::after{width:100%}
.header-cta{flex-shrink:0}
.header-cta .btn-outline{padding:10px 20px;font-size:.8125rem}
.main-navigation,#menu-toggle,.nav-mobile-cta,.mobile-logo{display:none!important}
}

/* === MOBILE (<769px) — NO HEADER, MENU DIRECT BODY CHILD === */
@media(max-width:768px){
.site-header{display:none!important}
.mobile-logo{
  display:flex!important;
  position:fixed!important;
  top:16px!important;
  left:20px!important;
  right:auto!important;
  z-index:99999;
  font-family:var(--font-heading);
  font-size:1.2rem;
  font-weight:700;
  color:#fff;
  flex-shrink:0;
  text-shadow:0 1px 6px rgba(0,0,0,.5);
  pointer-events:none;
  transform:none!important;
  translate:none!important;
  will-change:auto!important
}
.mobile-logo .logo-accent{color:#fff}

/* .main-navigation is a DIRECT child of <body> now */
.main-navigation{
  display:none!important;
  position:fixed!important;
  inset:0!important;
  width:100%!important;
  height:100%!important;
  background:var(--color-surface)!important;
  z-index:99998!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  overflow:hidden!important
}
.main-navigation.open{display:flex!important}

body.nav-open{overflow:hidden!important}

.nav-menu{flex-direction:column;gap:4px;text-align:center;width:100%}
.nav-menu a{font-family:var(--font-heading);font-size:1.75rem;font-weight:600;color:var(--color-text);display:block;padding:14px 20px}
.nav-mobile-cta{display:block;margin-top:32px}
#menu-toggle{
  display:flex!important;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  background:none;border:none;cursor:pointer;
  position:fixed!important;
  top:16px!important;
  right:20px!important;
  left:auto!important;
  width:28px!important;
  height:28px!important;padding:0;
  z-index:99999;
  transform:none!important;
  translate:none!important;
  will-change:auto!important
}
#menu-toggle span{display:block;width:100%;height:2.5px;background:#fff;border-radius:2px;transition:transform .3s,opacity .3s}
#menu-toggle.active span{background:var(--color-text)}
#menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
#menu-toggle.active span:nth-child(2){opacity:0}
#menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* === BUTTONS === */
.btn-primary,.btn-outline{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:14px 32px;border-radius:100px;transition:all .3s var(--transition-smooth);cursor:pointer;border:none;text-align:center;white-space:nowrap}
.btn-primary{background:var(--color-primary);color:#fff}
.btn-primary:hover{background:#005237;transform:translateY(-2px);box-shadow:0 8px 24px rgba(26,107,76,.3)}
.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}
.btn-outline:hover{background:var(--color-primary);color:#fff}
.btn-outline--light{color:#fff;border-color:#fff}
.btn-outline--light:hover{background:#fff;color:var(--color-primary-dark)}
.btn-glow{animation:glow-pulse 2s ease-in-out infinite}
@keyframes glow-pulse{0%,100%{box-shadow:0 0 20px rgba(26,107,76,.3)}50%{box-shadow:0 0 40px rgba(26,107,76,.5),0 0 60px rgba(26,107,76,.2)}}
@media(max-width:480px){.btn-primary,.btn-outline{padding:12px 24px;font-size:.8125rem;max-width:300px}}

/* === HERO === */
.hero-section{position:relative;width:100%;height:100vh;height:100dvh;min-height:568px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.hero-bg-video{position:absolute;inset:0;width:100%;height:100%}
.hero-video{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(13,53,38,.75) 0%,rgba(26,107,76,.45) 50%,rgba(0,0,0,.65) 100%)}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding:0 20px;max-width:800px}
.hero-badge{font-family:var(--font-body);font-size:.8125rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent-gold);display:block;margin-bottom:12px}
.hero-title{font-family:var(--font-heading);font-size:clamp(2.2rem,8vw,4.5rem);font-weight:700;line-height:1.1;letter-spacing:-.02em;margin-bottom:8px}
.hero-subtitle{font-family:var(--font-body);font-size:clamp(1rem,3vw,1.5rem);font-weight:400;color:rgba(255,255,255,.85);margin-bottom:32px}
.hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.scroll-indicator{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:2}
.scroll-mouse{display:block;width:22px;height:36px;border:2px solid rgba(255,255,255,.35);border-radius:11px;position:relative}
.scroll-wheel{display:block;width:3px;height:7px;background:#fff;border-radius:2px;position:absolute;top:7px;left:50%;transform:translateX(-50%);animation:scroll-bounce 1.5s ease-in-out infinite}
@keyframes scroll-bounce{0%,100%{opacity:1;transform:translateX(-50%) translateY(0)}50%{opacity:.5;transform:translateX(-50%) translateY(7px)}}
@media(max-width:768px){.hero-title{font-size:clamp(2rem,8vw,2.8rem)}.hero-subtitle{font-size:1rem;margin-bottom:24px}}
@media(max-width:480px){.hero-title{font-size:2rem}.hero-badge{font-size:.75rem}}

/* === ABOUT === */
.about-section{background:var(--color-surface)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media(max-width:768px){.about-grid{grid-template-columns:1fr;gap:32px;text-align:center}.about-grid .accent-line{margin:0 auto 20px}}
.about-image-frame{width:100%;max-width:420px;aspect-ratio:1;border-radius:50%;border:5px solid var(--color-primary);overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--color-surface-variant);margin:0 auto;box-shadow:0 10px 30px rgba(26,107,76,.25)}
@media(max-width:480px){.about-image-frame{max-width:260px}}
.about-image-frame img{width:100%;height:100%;object-fit:cover;display:block}
.profile-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.profile-initials{font-family:var(--font-heading);font-size:clamp(3rem,10vw,4rem);color:var(--color-primary);font-weight:700}
.about-text{font-size:1.0625rem;line-height:1.8;color:var(--color-text-light)}

/* === SKILLS === */
.skills-section{background:var(--color-bg)}
.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:1024px){.skills-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.skills-grid{grid-template-columns:1fr;gap:16px}}
.skill-card{background:var(--color-surface);border-radius:16px;padding:32px 24px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);transition:transform .4s var(--transition-smooth),box-shadow .4s var(--transition-smooth)}
.skill-card:hover{transform:translateY(-6px);box-shadow:0 12px 40px rgba(0,0,0,.1)}
@media(max-width:768px){.skill-card:hover{transform:none}.skill-card{padding:24px 20px}}
.skill-icon{width:56px;height:56px;background:var(--color-surface-variant);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.skill-title{font-family:var(--font-heading);font-size:1.125rem;font-weight:600;margin-bottom:16px;color:var(--color-text)}
.skill-bar-wrapper{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.skill-bar-bg{flex:1;height:8px;background:var(--color-surface-variant);border-radius:100px;overflow:hidden}
.skill-bar-fill{height:100%;width:0;background:linear-gradient(90deg,var(--color-primary),#2d8a65);border-radius:100px;transition:width 1.2s var(--transition-smooth)}
.skill-pct{font-family:var(--font-body);font-size:.75rem;font-weight:600;color:var(--color-primary);min-width:32px;text-align:right}
.skill-text{font-size:.875rem;color:var(--color-text-light);line-height:1.6}

/* === CONTACT === */
.contact-section{background:linear-gradient(135deg,var(--color-primary-dark),var(--color-primary));color:#fff;text-align:center}
.contact-content{max-width:600px;margin:0 auto}
.contact-headline{font-family:var(--font-heading);font-size:clamp(1.75rem,5vw,3rem);font-weight:600;margin-bottom:16px;color:#fff}
.contact-text{font-size:1.0625rem;color:rgba(255,255,255,.8);margin-bottom:36px;line-height:1.7}

/* === FOOTER === */
.site-footer{background:var(--color-primary-darker);color:rgba(255,255,255,.6);padding:24px 0}
.footer-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
@media(max-width:480px){.footer-content{flex-direction:column;text-align:center}}
.footer-text{font-size:.8125rem}
.footer-link{font-size:.8125rem;color:rgba(255,255,255,.6);transition:color .3s}
.footer-link:hover{color:var(--color-accent-gold)}

/* === LANDSCAPE + REDUCED MOTION === */
@media(max-height:500px) and (orientation:landscape){.hero-section{height:auto;padding:80px 0 40px}.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem;margin-bottom:16px}.scroll-indicator{display:none}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}