/* ═══════════════════════════════════════════════
   AcadeMy PMU – By Marzia Scannapieco
   PREMIUM Multi-Page CSS – Maximum WOW
═══════════════════════════════════════════════ */

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

:root{
  --rose:#c8829a;--rose-light:#e8b4c3;--rose-dark:#9e5b74;
  --gold:#d4a853;--gold-light:#f0d09a;
  --cream:#fdf6f0;
  --dark:#0d0811;--dark-mid:#1a0e14;--dark-soft:#2d1a24;
  --text:#f9eff5;--text-muted:#c9aab8;
  --glass-bg:rgba(255,255,255,0.04);
  --glass-border:rgba(200,130,154,0.18);
  --shadow-rose:0 20px 60px rgba(200,130,154,0.25);
  --shadow-gold:0 20px 60px rgba(212,168,83,0.2);
  --tr:all .5s cubic-bezier(.25,.46,.45,.94);
  --font-head:'Cormorant Garamond',serif;
  --font-body:'Outfit',sans-serif;
  --radius:20px;
}

html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--font-body);background:var(--dark);color:var(--text);overflow-x:hidden}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
em{font-style:italic;color:var(--rose-light)}
strong{color:var(--gold-light)}
ul{list-style:none}

/* ─── SCROLLBAR ─── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--dark)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--rose),var(--gold));border-radius:99px}

/* ─── GLOBAL PAGE TRANSITION ─── */
body{animation:pageIn .8s ease both}
@keyframes pageIn{from{opacity:0;filter:blur(8px)}to{opacity:1;filter:blur(0)}}

/* ─── CURSOR GLOW ─── */
#cursor-glow{
  pointer-events:none;position:fixed;top:0;left:0;
  width:350px;height:350px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,130,154,0.12) 0%,transparent 70%);
  transform:translate(-50%,-50%);z-index:9999;
  mix-blend-mode:screen;
  transition:width .3s,height .3s;
}

/* ─── PARTICLES CANVAS ─── */
#particles-canvas{position:fixed;inset:0;z-index:0;pointer-events:none}

/* ─── ANIMATED BACKGROUND MESH ─── */
.bg-mesh{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 50% 50% at 20% 20%,rgba(158,91,116,0.08) 0%,transparent 60%),
    radial-gradient(ellipse 40% 50% at 80% 80%,rgba(212,168,83,0.06) 0%,transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 50%,rgba(200,130,154,0.04) 0%,transparent 60%);
  animation:meshMove 15s ease-in-out infinite alternate;
}
@keyframes meshMove{
  0%{background-position:0% 0%,100% 100%,50% 50%}
  100%{background-position:20% 30%,70% 20%,30% 80%}
}

/* ─── REVEAL ANIMATIONS ─── */
.reveal{opacity:0;transform:translateY(50px);transition:opacity 1s ease,transform 1s cubic-bezier(.19,1,.22,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-80px);transition:opacity 1s ease,transform 1s cubic-bezier(.19,1,.22,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(80px);transition:opacity 1s ease,transform 1s cubic-bezier(.19,1,.22,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.85);transition:opacity 1s ease,transform 1s cubic-bezier(.19,1,.22,1)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* ─── BUTTONS ─── */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  padding:16px 36px;
  background:linear-gradient(135deg,var(--rose),var(--rose-dark));
  color:#fff;font-family:var(--font-body);font-weight:600;font-size:.95rem;
  letter-spacing:.05em;border-radius:99px;border:none;cursor:pointer;
  transition:var(--tr);box-shadow:0 8px 30px rgba(200,130,154,0.4);
  position:relative;overflow:hidden;
}
.btn-primary::before{
  content:'';position:absolute;inset:-1px;
  background:linear-gradient(135deg,rgba(255,255,255,.25),transparent 50%);
  opacity:0;transition:var(--tr);border-radius:inherit;
}
.btn-primary::after{
  content:'';position:absolute;top:50%;left:50%;
  width:0;height:0;border-radius:50%;
  background:rgba(255,255,255,.15);
  transition:width .6s ease,height .6s ease,top .6s ease,left .6s ease;
}
.btn-primary:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 20px 50px rgba(200,130,154,.5)}
.btn-primary:hover::before{opacity:1}
.btn-primary:hover::after{width:300px;height:300px;top:-100px;left:-100px}
.btn-primary.large{padding:20px 52px;font-size:1.1rem}
.btn-primary.full-width{width:100%;justify-content:center}

.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  padding:16px 36px;background:transparent;
  color:var(--rose-light);font-family:var(--font-body);
  font-weight:500;font-size:.95rem;letter-spacing:.05em;
  border-radius:99px;border:1.5px solid var(--rose-light);
  cursor:pointer;transition:var(--tr);position:relative;overflow:hidden;
}
.btn-outline::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(200,130,154,.15),transparent);
  opacity:0;transition:var(--tr);
}
.btn-outline:hover{border-color:var(--rose);transform:translateY(-4px);background:rgba(200,130,154,.08)}
.btn-outline:hover::after{opacity:1}

/* ─── SECTION COMMON ─── */
section{position:relative;z-index:1}
.section-label{
  font-family:var(--font-body);font-size:.72rem;font-weight:600;
  letter-spacing:.35em;text-transform:uppercase;color:var(--gold);
  margin-bottom:16px;
  display:flex;align-items:center;gap:16px;
}
.section-label::before,.section-label::after{
  content:'';flex:0 0 24px;height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
}
.section-label::after{background:linear-gradient(90deg,transparent,var(--gold))}
.section-label.centered{justify-content:center}

.section-title{
  font-family:var(--font-head);font-size:clamp(2.4rem,5vw,4.2rem);
  font-weight:300;line-height:1.12;margin-bottom:24px;
}
.section-title.centered{text-align:center}
.section-sub{
  text-align:center;color:var(--text-muted);font-size:1.05rem;
  max-width:560px;margin:0 auto 64px;line-height:1.7;
}

/* ─── GLASSMORPHISM ─── */
.glassmorphism{
  background:var(--glass-bg);border:1px solid var(--glass-border);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
}

/* ─── TEXT SHIMMER ─── */
.shimmer{
  background:linear-gradient(90deg,var(--text) 0%,var(--rose-light) 30%,var(--gold-light) 50%,var(--rose-light) 70%,var(--text) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  animation:shimmer 4s ease-in-out infinite;
}
@keyframes shimmer{0%,100%{background-position:200% 0}50%{background-position:0% 0}}

/* ─── GLOWING DIVIDER ─── */
.glow-divider{
  width:100%;max-width:300px;height:2px;margin:0 auto 0;
  background:linear-gradient(90deg,transparent,var(--rose),var(--gold),var(--rose),transparent);
  border-radius:99px;
  animation:glowPulse 3s ease-in-out infinite;
}
@keyframes glowPulse{0%,100%{opacity:.5;box-shadow:none}50%{opacity:1;box-shadow:0 0 20px rgba(200,130,154,.4)}}

/* ══════════ NAVBAR ══════════ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 60px;transition:var(--tr);
}
#navbar.scrolled{
  background:rgba(13,8,17,.88);backdrop-filter:blur(24px);
  padding:12px 60px;border-bottom:1px solid var(--glass-border);
  box-shadow:0 4px 30px rgba(0,0,0,.3);
}
.nav-logo{height:56px;display:flex;align-items:center}
#nav-logo-img{height:100%;width:auto;object-fit:contain;filter:invert(1) brightness(2)}
.nav-links{display:flex;list-style:none;gap:36px}
.nav-links a{
  font-size:.88rem;font-weight:500;letter-spacing:.06em;
  color:var(--text-muted);transition:var(--tr);position:relative;padding:4px 0;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:50%;width:0;height:2px;
  background:linear-gradient(90deg,var(--rose-light),var(--gold-light));
  transition:var(--tr);border-radius:99px;transform:translateX(-50%);
}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-links a.active{color:var(--rose-light)}
.nav-links a.active::after{width:100%}
.nav-cta{
  padding:11px 26px;
  background:linear-gradient(135deg,var(--rose),var(--rose-dark));
  color:#fff;font-weight:600;font-size:.83rem;border-radius:99px;
  transition:var(--tr);box-shadow:0 4px 20px rgba(200,130,154,.3);
}
.nav-cta:hover{transform:scale(1.06);box-shadow:0 8px 30px rgba(200,130,154,.5)}
.hamburger{display:none;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;padding:4px}
.hamburger span{display:block;width:26px;height:2px;background:var(--text);transition:var(--tr);border-radius:99px}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}

/* ─── Mobile Menu ─── */
.mobile-menu{
  display:none;position:fixed;top:70px;left:0;right:0;
  background:rgba(13,8,17,.97);backdrop-filter:blur(24px);
  padding:32px 40px;border-bottom:1px solid var(--glass-border);
  z-index:999;flex-direction:column;gap:24px;
  animation:slideDown .4s ease;
}
.mobile-menu.show{display:flex}
@keyframes slideDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu a{
  font-size:1.1rem;color:var(--text-muted);padding:8px 0;
  border-bottom:1px solid rgba(200,130,154,.1);transition:var(--tr);
}
.mobile-menu a:hover{color:var(--rose-light);padding-left:12px}

/* ══════════ HERO ══════════ */
#hero{
  min-height:100vh;display:grid;grid-template-columns:1fr 1fr;
  align-items:center;gap:80px;padding:140px 80px 100px;
  position:relative;overflow:hidden;
}
.hero-bg-shapes{position:absolute;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.hero-shape{
  position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;
  animation:morphFloat 20s ease-in-out infinite alternate;
}
.hero-shape:nth-child(1){
  width:600px;height:600px;top:-200px;right:-100px;
  background:linear-gradient(135deg,var(--rose),var(--gold));
}
.hero-shape:nth-child(2){
  width:400px;height:400px;bottom:-100px;left:-100px;
  background:linear-gradient(135deg,var(--gold),var(--rose-dark));
  animation-delay:-7s;
}
.hero-shape:nth-child(3){
  width:300px;height:300px;top:50%;left:40%;
  background:var(--rose-light);animation-delay:-12s;
}
@keyframes morphFloat{
  0%{transform:translate(0,0) scale(1) rotate(0deg);border-radius:50%}
  33%{transform:translate(30px,-40px) scale(1.1) rotate(120deg);border-radius:40% 60% 50% 50%}
  66%{transform:translate(-20px,30px) scale(.95) rotate(240deg);border-radius:60% 40% 60% 40%}
  100%{transform:translate(10px,-10px) scale(1.05) rotate(360deg);border-radius:50%}
}

.hero-bg-pattern{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    radial-gradient(circle at 1px 1px,rgba(200,130,154,.06) 1px,transparent 0);
  background-size:40px 40px;
}

.hero-content{position:relative;z-index:1}
.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 24px;
  background:linear-gradient(135deg,rgba(212,168,83,.12),rgba(200,130,154,.08));
  border:1px solid rgba(212,168,83,.3);border-radius:99px;
  font-size:.75rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-light);margin-bottom:32px;
  animation:badgePulse 3s ease-in-out infinite;
}
@keyframes badgePulse{0%,100%{box-shadow:0 0 0 0 rgba(212,168,83,.15)}50%{box-shadow:0 0 0 12px rgba(212,168,83,0)}}

.hero-title{font-family:var(--font-head);line-height:.92;margin-bottom:16px}
.hero-title .line1{
  display:block;font-size:clamp(3.2rem,7vw,6rem);font-weight:300;
  letter-spacing:-.02em;color:var(--text);
}
.hero-title .line1 em{font-weight:700;color:var(--rose-light);font-style:normal}
.hero-title .line2{
  display:block;font-size:clamp(5rem,12vw,11rem);font-weight:700;
  letter-spacing:-.05em;line-height:.85;
}
.hero-subtitle{
  font-family:var(--font-head);font-size:clamp(1rem,2.5vw,1.4rem);
  font-weight:300;color:var(--text-muted);margin-bottom:24px;font-style:italic;
}
.hero-desc{font-size:1rem;color:var(--text-muted);line-height:1.8;margin-bottom:44px;max-width:480px}
.hero-buttons{display:flex;gap:16px;flex-wrap:wrap}

.hero-image-wrap{position:relative;z-index:1;perspective:800px}
.hero-image-glow{
  position:absolute;inset:-50px;
  background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(200,130,154,.3),transparent 70%);
  filter:blur(40px);z-index:-1;animation:pulse-glow 4s ease-in-out infinite alternate;
}
@keyframes pulse-glow{from{opacity:.5;transform:scale(1)}to{opacity:1;transform:scale(1.1)}}

.hero-img{
  width:100%;border-radius:28px;
  box-shadow:var(--shadow-rose),0 0 0 1px var(--glass-border);
  object-fit:cover;aspect-ratio:4/5;
  transition:transform .6s cubic-bezier(.25,.46,.45,.94);
  animation:heroFloat 6s ease-in-out infinite;
}
@keyframes heroFloat{0%,100%{transform:translateY(0) rotateX(0) rotateY(0)}50%{transform:translateY(-14px) rotateX(1deg) rotateY(-1deg)}}

.hero-img-badge{
  position:absolute;bottom:-24px;left:-24px;
  padding:22px 28px;
  background:linear-gradient(135deg,var(--dark-mid),var(--dark-soft));
  border:1px solid var(--glass-border);border-radius:var(--radius);
  backdrop-filter:blur(20px);display:flex;flex-direction:column;align-items:center;
  box-shadow:var(--shadow-rose);animation:heroFloat 6s ease-in-out infinite reverse;
}
.badge-num{
  font-family:var(--font-head);font-size:2.4rem;font-weight:700;line-height:1;
}
.badge-text{font-size:.72rem;color:var(--text-muted);text-align:center;letter-spacing:.05em;margin-top:4px}

.scroll-indicator{
  position:absolute;bottom:40px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);
  animation:fadeUpLoop 2.5s ease-in-out infinite;
}
@keyframes fadeUpLoop{0%,100%{opacity:.3;transform:translateX(-50%) translateY(0)}50%{opacity:1;transform:translateX(-50%) translateY(-8px)}}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--rose-light),transparent)}

/* ══════════ PHOTO BG SECTIONS ══════════ */
.photo-bg{
  position:relative;overflow:hidden;
}
.photo-bg-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.08;filter:blur(2px) saturate(1.2);pointer-events:none;
  transition:opacity 1s ease;
}
.photo-bg-img.loaded{opacity:.1}
.photo-bg::after{
  content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,var(--dark) 0%,rgba(13,8,17,.85) 50%,var(--dark) 100%);
  pointer-events:none;
}
.photo-bg>*:not(.photo-bg-img):not(.cta-glow){position:relative;z-index:1}

/* ═══ About Image ═══ */
.about-image-wrap{
  position:relative;border-radius:20px;overflow:hidden;
  box-shadow:var(--shadow-rose);margin-top:20px;
}
.about-image-wrap img{
  width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;
  transition:transform .8s cubic-bezier(.19,1,.22,1);
}
.about-image-wrap:hover img{transform:scale(1.05)}
.about-image-wrap::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(13,8,17,.5) 0%,transparent 50%);
  pointer-events:none;
}

/* ══════════ STATS ══════════ */
#stats{
  background:linear-gradient(135deg,var(--dark-mid),var(--dark));
  border-top:1px solid var(--glass-border);border-bottom:1px solid var(--glass-border);
  padding:70px 80px;position:relative;overflow:hidden;
}
#stats::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(200,130,154,.03),transparent);
  animation:statsShine 5s ease-in-out infinite;
}
@keyframes statsShine{0%,100%{transform:translateX(-100%)}50%{transform:translateX(100%)}}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;max-width:1200px;margin:auto;position:relative;z-index:1}
.stat-item{text-align:center;transition:var(--tr)}
.stat-item:hover{transform:scale(1.08)}
.stat-num{font-family:var(--font-head);font-size:3.8rem;font-weight:700;line-height:1}
.stat-plus{font-family:var(--font-head);font-size:2.5rem}
.stat-label{display:block;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-top:8px}

/* ══════════ ABOUT ══════════ */
#about{padding:130px 80px;background:var(--dark);max-width:1400px;margin:auto}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.about-text p{color:var(--text-muted);line-height:1.85;font-size:1.05rem;margin-bottom:18px}
.about-features{margin-top:36px;display:flex;flex-direction:column;gap:14px}
.about-features li{
  font-size:.95rem;color:var(--text-muted);padding:10px 16px;
  border-left:2px solid transparent;transition:var(--tr);
  border-radius:0 8px 8px 0;
}
.about-features li:hover{
  color:var(--rose-light);border-left-color:var(--rose);
  background:rgba(200,130,154,.05);padding-left:24px;
}

.about-visual{display:flex;flex-direction:column;gap:20px}
.about-card{
  padding:30px 34px;border-radius:var(--radius);transition:var(--tr);
  position:relative;overflow:hidden;
}
.about-card::before{
  content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:conic-gradient(from 0deg,transparent,rgba(200,130,154,.08),transparent,rgba(212,168,83,.06),transparent);
  animation:cardRotate 8s linear infinite;
  opacity:0;transition:opacity .5s;
}
.about-card:hover::before{opacity:1}
@keyframes cardRotate{to{transform:rotate(360deg)}}
.about-card:hover{border-color:rgba(200,130,154,.4);transform:translateX(10px);box-shadow:var(--shadow-rose)}
.about-card-icon{font-size:2.2rem;margin-bottom:14px}
.about-card h3{font-family:var(--font-head);font-size:1.3rem;font-weight:600;margin-bottom:8px;color:var(--text)}
.about-card p{font-size:.9rem;color:var(--text-muted);line-height:1.6;position:relative;z-index:1}

/* ══════════ COURSES ══════════ */
#courses{
  padding:130px 80px;
  background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(158,91,116,.1) 0%,transparent 60%),var(--dark-mid);
  text-align:center;
}
.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1200px;margin:auto}
.course-card{
  background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:var(--radius);padding:44px 32px;text-align:left;
  transition:var(--tr);position:relative;backdrop-filter:blur(10px);
  overflow:hidden;
}
.course-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--rose),var(--gold),var(--rose));
  background-size:200% 100%;animation:shimmer 4s ease-in-out infinite;
  opacity:0;transition:opacity .5s;
}
.course-card:hover::before{opacity:1}
.course-card:hover{transform:translateY(-14px);border-color:rgba(200,130,154,.4);box-shadow:var(--shadow-rose)}
.course-card.featured{border-color:rgba(212,168,83,.4);background:linear-gradient(135deg,rgba(212,168,83,.06),rgba(200,130,154,.06))}
.course-card.featured:hover{box-shadow:var(--shadow-gold)}
.course-icon{font-size:2.8rem;margin-bottom:18px}
.course-tag{
  display:inline-block;padding:5px 16px;
  background:rgba(200,130,154,.12);border:1px solid rgba(200,130,154,.25);
  border-radius:99px;font-size:.7rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--rose-light);margin-bottom:18px;
}
.featured-tag{background:rgba(212,168,83,.12);border-color:rgba(212,168,83,.25);color:var(--gold-light)}
.course-card h3{font-family:var(--font-head);font-size:1.45rem;font-weight:600;margin-bottom:12px;color:var(--text)}
.course-card>p{font-size:.9rem;color:var(--text-muted);line-height:1.7;margin-bottom:22px}
.course-details{margin-bottom:28px;display:flex;flex-direction:column;gap:8px}
.course-details li{font-size:.85rem;color:var(--text-muted)}
.btn-course{
  display:inline-block;padding:13px 30px;
  border:1.5px solid var(--rose-light);border-radius:99px;
  color:var(--rose-light);font-size:.85rem;font-weight:600;
  letter-spacing:.05em;transition:var(--tr);
}
.btn-course:hover{background:var(--rose);border-color:var(--rose);color:#fff;transform:scale(1.06)}
.featured-btn{
  background:linear-gradient(135deg,var(--gold),var(--rose));border:none;
  color:#fff;box-shadow:0 8px 30px rgba(212,168,83,.3);
}
.featured-btn:hover{transform:scale(1.06);box-shadow:0 16px 50px rgba(212,168,83,.4)}

/* ══════════ GALLERY ══════════ */
#gallery-section{
  padding:130px 80px;background:var(--dark);max-width:1400px;margin:auto;text-align:center;
}
.gallery-masonry{
  display:grid;grid-template-columns:repeat(3,1fr);
  grid-auto-rows:280px;gap:16px;max-width:1200px;margin:auto;
}
.gallery-item{
  position:relative;border-radius:16px;overflow:hidden;cursor:pointer;
}
.gallery-item.large{grid-row:span 2}
.gallery-item.wide{grid-column:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.19,1,.22,1),filter .5s ease}
.gallery-item:hover img{transform:scale(1.12);filter:brightness(1.1)}
.gallery-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(13,8,17,.92) 0%,rgba(13,8,17,.3) 40%,transparent 70%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:28px;
  opacity:0;transition:var(--tr);
}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay span{font-family:var(--font-head);font-size:1.25rem;font-weight:600;color:var(--text)}
.gallery-overlay small{font-size:.8rem;color:var(--rose-light);margin-top:4px}

/* ─── LIGHTBOX ─── */
.lightbox{
  display:none;position:fixed;inset:0;z-index:10000;
  background:rgba(0,0,0,.92);backdrop-filter:blur(20px);
  align-items:center;justify-content:center;
  animation:lbIn .4s ease;
}
.lightbox.active{display:flex}
@keyframes lbIn{from{opacity:0}to{opacity:1}}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:16px;box-shadow:0 0 80px rgba(200,130,154,.3)}
.lightbox-close{
  position:fixed;top:30px;right:40px;
  background:rgba(200,130,154,.2);border:1px solid rgba(200,130,154,.3);
  color:#fff;font-size:1.5rem;width:50px;height:50px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:var(--tr);backdrop-filter:blur(10px);
}
.lightbox-close:hover{background:var(--rose);transform:rotate(90deg)}

/* ══════════ TESTIMONIALS ══════════ */
#testimonials{
  padding:130px 80px;background:var(--dark-mid);text-align:center;overflow:hidden;
}
.testimonials-wrapper{
  display:flex;gap:24px;padding:20px 0 40px;overflow-x:auto;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;max-width:1200px;margin:auto;
}
.testimonials-wrapper::-webkit-scrollbar{display:none}
.testimonial-card{
  min-width:320px;max-width:360px;padding:36px 32px;
  border-radius:var(--radius);text-align:left;scroll-snap-align:start;
  flex-shrink:0;transition:var(--tr);
}
.testimonial-card:hover{border-color:rgba(200,130,154,.4);transform:translateY(-10px)}
.stars{color:var(--gold);font-size:1.1rem;margin-bottom:16px;letter-spacing:3px}
.testimonial-card p{font-size:.92rem;color:var(--text-muted);line-height:1.7;font-style:italic;margin-bottom:24px}
.testimonial-author{display:flex;align-items:center;gap:12px}
.author-avatar{
  width:44px;height:44px;border-radius:50%;
  background:linear-gradient(135deg,var(--rose),var(--gold));
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:1rem;color:#fff;flex-shrink:0;
}
.testimonial-author strong{display:block;font-size:.95rem;color:var(--text)}
.testimonial-author small{font-size:.78rem;color:var(--rose-light)}

/* ══════════ CTA BANNER ══════════ */
#cta-banner{
  padding:130px 80px;text-align:center;
  background:radial-gradient(ellipse 70% 80% at 50% 50%,rgba(158,91,116,.18) 0%,transparent 70%),var(--dark);
  position:relative;overflow:hidden;
}
.cta-glow{
  position:absolute;width:700px;height:700px;border-radius:50%;
  background:radial-gradient(circle,rgba(200,130,154,.18),transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%);filter:blur(80px);
  animation:pulse-glow 5s ease-in-out infinite alternate;
}
.cta-content{position:relative;z-index:1}
.cta-content h2{font-family:var(--font-head);font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;line-height:1.15;margin-bottom:20px}
.cta-content p{color:var(--text-muted);font-size:1.1rem;margin-bottom:40px}

/* ══════════ CONTACT ══════════ */
#contact-section{
  padding:130px 80px;background:var(--dark-mid);max-width:1400px;margin:auto;
}
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:80px;align-items:start;max-width:1200px;margin:auto}
.contact-info{display:flex;flex-direction:column;gap:24px;padding-top:40px}
.contact-item{
  display:flex;align-items:center;gap:20px;padding:22px 26px;
  background:var(--glass-bg);border:1px solid var(--glass-border);
  border-radius:var(--radius);transition:var(--tr);
}
.contact-item:hover{border-color:rgba(200,130,154,.4);transform:translateX(8px);box-shadow:0 8px 30px rgba(200,130,154,.1)}
.contact-icon{font-size:1.8rem}
.contact-item strong{display:block;font-size:.95rem;color:var(--text);margin-bottom:4px}
.contact-item span{font-size:.85rem;color:var(--text-muted)}

.contact-form{padding:52px;border-radius:28px}
.contact-form h3{font-family:var(--font-head);font-size:1.8rem;font-weight:400;margin-bottom:36px;color:var(--text)}
.form-group{margin-bottom:22px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:16px 22px;
  background:rgba(255,255,255,.04);border:1px solid var(--glass-border);
  border-radius:14px;color:var(--text);font-family:var(--font-body);
  font-size:.95rem;outline:none;transition:var(--tr);resize:none;
}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(200,170,184,.4)}
.form-group select{appearance:none;cursor:pointer}
.form-group select option{background:var(--dark-mid);color:var(--text)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--rose);box-shadow:0 0 0 4px rgba(200,130,154,.12);
  background:rgba(200,130,154,.04);
}
.form-note{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:16px}

/* ═══ FORM SUCCESS ANIMATION ═══ */
.form-success{
  display:none;text-align:center;padding:60px 40px;
  animation:successIn .6s ease;
}
.form-success.show{display:block}
@keyframes successIn{from{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}
.success-icon{font-size:4rem;margin-bottom:20px;animation:successBounce .8s ease .3s both}
@keyframes successBounce{0%{transform:scale(0)}50%{transform:scale(1.3)}100%{transform:scale(1)}}

/* ══════════ ADMIN DASHBOARD ══════════ */
.admin-page{padding:120px 60px 80px;max-width:1200px;margin:auto}
.admin-header{margin-bottom:48px}
.admin-header h1{font-family:var(--font-head);font-size:2.8rem;font-weight:300;margin-bottom:12px}
.admin-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px}
.admin-stat-card{
  padding:28px;border-radius:var(--radius);
  background:var(--glass-bg);border:1px solid var(--glass-border);
  backdrop-filter:blur(10px);transition:var(--tr);
}
.admin-stat-card:hover{border-color:rgba(200,130,154,.4);transform:translateY(-4px)}
.admin-stat-card .stat-value{font-family:var(--font-head);font-size:2.5rem;font-weight:700;margin-bottom:4px}
.admin-stat-card .stat-desc{font-size:.85rem;color:var(--text-muted)}

.messages-list{display:flex;flex-direction:column;gap:16px}
.message-card{
  padding:28px 32px;border-radius:var(--radius);
  background:var(--glass-bg);border:1px solid var(--glass-border);
  backdrop-filter:blur(10px);transition:var(--tr);position:relative;overflow:hidden;
}
.message-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--rose),var(--gold));
}
.message-card:hover{border-color:rgba(200,130,154,.3);transform:translateX(4px)}
.message-card.unread{border-color:rgba(200,130,154,.3);background:rgba(200,130,154,.04)}
.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.message-name{font-weight:600;color:var(--text);font-size:1.05rem}
.message-date{font-size:.78rem;color:var(--text-muted)}
.message-course{
  display:inline-block;padding:3px 12px;
  background:rgba(212,168,83,.12);border:1px solid rgba(212,168,83,.2);
  border-radius:99px;font-size:.7rem;color:var(--gold-light);
  font-weight:600;letter-spacing:.05em;margin-bottom:8px;
}
.message-contact{font-size:.85rem;color:var(--text-muted);margin-bottom:8px}
.message-body{font-size:.92rem;color:var(--text-muted);line-height:1.7}
.message-actions{margin-top:16px;display:flex;gap:8px}
.msg-btn{
  padding:8px 18px;border-radius:99px;font-size:.78rem;font-weight:600;
  border:1px solid var(--glass-border);background:transparent;
  color:var(--text-muted);cursor:pointer;transition:var(--tr);
}
.msg-btn:hover{background:var(--rose);border-color:var(--rose);color:#fff}
.msg-btn.delete:hover{background:#c0392b;border-color:#c0392b}
.empty-state{
  text-align:center;padding:80px 40px;color:var(--text-muted);
}
.empty-state .empty-icon{font-size:4rem;margin-bottom:20px}

/* ══════════ PAGE HEADER (for inner pages) ══════════ */
.page-header{
  padding:180px 80px 80px;text-align:center;position:relative;
  background:var(--dark);overflow:hidden;
}
.page-header .page-header-bg{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:.06;filter:blur(3px) saturate(1.3);pointer-events:none;
}
.page-header::before{
  content:'';position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse 60% 70% at 50% 30%,rgba(158,91,116,.18) 0%,transparent 60%),
    linear-gradient(180deg,var(--dark) 0%,rgba(13,8,17,.7) 50%,var(--dark) 100%);
  pointer-events:none;
}
.page-header::after{
  content:'';position:absolute;inset:0;z-index:1;
  background-image:radial-gradient(circle at 1px 1px,rgba(200,130,154,.04) 1px,transparent 0);
  background-size:40px 40px;pointer-events:none;
}
.page-header h1{
  font-family:var(--font-head);font-size:clamp(3rem,7vw,5.5rem);
  font-weight:300;line-height:1;margin-bottom:20px;position:relative;z-index:2;
}
.page-header p{
  color:var(--text-muted);font-size:1.1rem;max-width:500px;margin:0 auto;
  position:relative;line-height:1.7;z-index:2;
}
.page-header .glow-divider{position:relative;z-index:2}

/* ══════════ FOOTER ══════════ */
#footer{
  background:var(--dark);border-top:1px solid var(--glass-border);
  padding:60px 80px 40px;text-align:center;
}
.footer-logo{height:60px;width:auto;margin:auto auto 20px;object-fit:contain;filter:invert(1) brightness(1.5)}
.footer-tagline{font-family:var(--font-head);font-style:italic;color:var(--text-muted);margin-bottom:32px}
.footer-links{display:flex;gap:36px;justify-content:center;flex-wrap:wrap;margin-bottom:32px}
.footer-links a{font-size:.85rem;letter-spacing:.08em;color:var(--text-muted);transition:var(--tr);position:relative}
.footer-links a::after{
  content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;
  background:var(--rose-light);transition:var(--tr);
}
.footer-links a:hover{color:var(--rose-light)}
.footer-links a:hover::after{width:100%}
.footer-copy{font-size:.78rem;color:rgba(200,170,184,.35)}

/* ══════════ RESPONSIVE ══════════ */
@media(max-width:1100px){
  #hero,.about-grid{grid-template-columns:1fr;gap:60px}
  #hero{padding:120px 40px 80px}
  .hero-image-wrap{max-width:500px;margin:auto}
  .courses-grid{grid-template-columns:1fr 1fr}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .contact-grid{grid-template-columns:1fr;gap:48px}
  .gallery-masonry{grid-template-columns:1fr 1fr}
  .admin-stats{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  #navbar{padding:16px 24px}
  .nav-links,.nav-cta{display:none}
  .hamburger{display:flex}
  #hero{padding:100px 24px 60px}
  .hero-title .line1{font-size:2.8rem}
  .hero-title .line2{font-size:4.5rem}
  .courses-grid,.gallery-masonry{grid-template-columns:1fr}
  .gallery-item.large,.gallery-item.wide{grid-row:auto;grid-column:auto}
  #stats,.about-grid,.courses-grid,.contact-grid{padding:80px 24px}
  section{padding-left:24px!important;padding-right:24px!important}
  .page-header{padding:140px 24px 60px}
  .contact-form{padding:32px 24px}
  .admin-page{padding:100px 20px 60px}
  .admin-stats{grid-template-columns:1fr}
  #footer{padding:40px 24px}
}
