/* =========================================================
   AMIRA YASSIN — MAGICAL FANTASY PORTFOLIO
   ========================================================= */

/* --- GOOGLE FONTS IMPORT --- */
@import url('https://fonts.googleapis.com/css2?family=Cinzel+Decorative:wght@400;700;900&family=Cinzel:wght@400;500;600;700&family=Lora:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

/* --- CSS VARIABLES --- */
:root {
  --bg:         #070d08;
  --bg2:        #0b1510;
  --bg3:        #0f1c12;
  --surface:    rgba(15,28,18,0.75);
  --surface2:   rgba(22,40,24,0.85);
  --gold:       #c9a84c;
  --gold-light: #e8d48b;
  --gold-dim:   #7a6230;
  --sage:       #4a7a52;
  --sage-light: #6aaa74;
  --emerald:    #1e4d25;
  --parchment:  #f0e3c0;
  --text:       #d4c8a0;
  --text-dim:   #8a7a58;
  --text-mute:  #4a4535;
  --border:     rgba(201,168,76,0.18);
  --border-hv:  rgba(201,168,76,0.5);
  --glow-gold:  0 0 20px rgba(201,168,76,0.4);
  --glow-sage:  0 0 20px rgba(74,122,82,0.4);
  --radius:     12px;
  --transition: 0.4s cubic-bezier(0.25,0.8,0.25,1);
}

/* --- RESET & BASE --- */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Lora',Georgia,serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  cursor:none;
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; display:block; }
ul { list-style:none; }
.container { max-width:1200px; margin:0 auto; padding:0 2rem; }

/* --- MAGIC CANVAS --- */
#magicCanvas {
  position:fixed; top:0; left:0;
  width:100%; height:100%;
  pointer-events:none; z-index:1;
}

/* --- CUSTOM CURSOR --- */
.cursor-orb {
  position:fixed; width:14px; height:14px;
  background:var(--gold); border-radius:50%;
  pointer-events:none; z-index:9999;
  transform:translate(-50%,-50%);
  box-shadow:0 0 12px var(--gold),0 0 24px rgba(201,168,76,0.5);
  transition:transform 0.1s,opacity 0.3s;
}
.cursor-trail {
  position:fixed; width:36px; height:36px;
  border:1px solid rgba(201,168,76,0.4);
  border-radius:50%; pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform 0.18s ease,width 0.3s,height 0.3s;
}

/* --- FOG LAYERS --- */
.fog-layer {
  position:fixed; top:0; left:0;
  width:200%; height:100%;
  pointer-events:none; z-index:2;
  background:radial-gradient(ellipse 80% 60% at 30% 50%,
    rgba(14,30,16,0.35) 0%, transparent 70%);
}
.fog-1 { animation:fogDrift 22s ease-in-out infinite alternate; }
.fog-2 {
  background:radial-gradient(ellipse 70% 50% at 70% 40%,
    rgba(10,25,12,0.3) 0%, transparent 70%);
  animation:fogDrift 30s ease-in-out infinite alternate-reverse;
}
.fog-3 {
  background:radial-gradient(ellipse 60% 40% at 50% 80%,
    rgba(8,18,10,0.25) 0%, transparent 70%);
  animation:fogDrift 18s ease-in-out infinite alternate;
}
@keyframes fogDrift {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

/* --- SECTION FOG --- */
.section-fog {
  position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 40% at 50% 0%,
    rgba(201,168,76,0.03) 0%, transparent 70%);
  pointer-events:none; z-index:0;
}

/* --- SCROLL ANIMATIONS --- */
.reveal-up, .reveal-left, .reveal-right {
  opacity:0; transition:opacity 0.9s var(--transition),
  transform 0.9s var(--transition);
}
.reveal-up    { transform:translateY(50px); }
.reveal-left  { transform:translateX(-60px); }
.reveal-right { transform:translateX(60px); }
.reveal-up.visible,
.reveal-left.visible,
.reveal-right.visible { opacity:1; transform:none; }
.delay-1 { transition-delay:0.1s; }
.delay-2 { transition-delay:0.2s; }
.delay-3 { transition-delay:0.3s; }
.delay-4 { transition-delay:0.4s; }

/* --- SECTION BASE --- */
.section { position:relative; padding:7rem 0; overflow:hidden; z-index:3; }

/* --- SECTION HEADER --- */
.section-header { text-align:center; margin-bottom:4rem; }
.section-eyebrow {
  font-family:'Cinzel',serif;
  font-size:0.75rem; letter-spacing:0.35em;
  color:var(--gold); text-transform:uppercase; margin-bottom:0.75rem;
}
.section-title {
  font-family:'Cinzel',serif;
  font-size:clamp(2rem,4vw,3rem);
  font-weight:700; color:var(--parchment);
  text-shadow:0 0 30px rgba(201,168,76,0.2);
  margin-bottom:1.25rem;
}
.magic-divider {
  display:flex; align-items:center;
  justify-content:center; gap:1rem;
  color:var(--gold); font-size:1rem;
}
.magic-divider span {
  display:block; width:80px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}

/* =========================================================
   NAVBAR
   ========================================================= */
.navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:1.25rem 0;
  transition:all 0.5s ease;
  background:transparent;
}
.navbar.scrolled {
  background:rgba(7,13,8,0.92);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  padding:0.85rem 0;
  box-shadow:0 4px 30px rgba(0,0,0,0.5),0 1px 0 var(--border);
}
.nav-container {
  max-width:1200px; margin:0 auto; padding:0 2rem;
  display:flex; align-items:center; justify-content:space-between;
}
.logo {
  font-family:'Cinzel Decorative',serif;
  font-size:1.15rem; display:flex; align-items:center; gap:0.4rem;
}
.logo-first { color:var(--parchment); }
.logo-last  { color:var(--gold); }
.logo-rune  { color:var(--gold); font-size:0.7rem; opacity:0.7;
  animation:runeFloat 3s ease-in-out infinite alternate; }
@keyframes runeFloat {
  from { transform:translateY(0) rotate(0deg); }
  to   { transform:translateY(-3px) rotate(15deg); }
}
.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-link {
  font-family:'Cinzel',serif; font-size:0.8rem; font-weight:500;
  letter-spacing:0.1em; text-transform:uppercase;
  color:var(--text-dim); position:relative;
  transition:color var(--transition);
}
.nav-link::after {
  content:''; position:absolute; bottom:-4px; left:0; right:0;
  height:1px; background:var(--gold); transform:scaleX(0);
  transition:transform var(--transition);
}
.nav-link:hover, .nav-link.active { color:var(--gold); }
.nav-link:hover::after, .nav-link.active::after { transform:scaleX(1); }
.mobile-menu-btn {
  display:none; background:none; border:1px solid var(--border);
  color:var(--gold); width:40px; height:40px; border-radius:6px;
  cursor:none; font-size:1rem; transition:all var(--transition);
}
.mobile-menu-btn:hover { background:var(--border); }

/* =========================================================
   HERO
   ========================================================= */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden; z-index:3;
}
.hero-bg-image {
  position:absolute; inset:0; z-index:0;
  background-image:url('../images/hero-bg.png');
  background-size:cover; background-position:center;
  transform:scale(1.05);
  animation:heroZoom 20s ease-in-out infinite alternate;
}
@keyframes heroZoom {
  from { transform:scale(1.05); }
  to   { transform:scale(1.12); }
}
.hero-overlay {
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(
    to bottom,
    rgba(7,13,8,0.6) 0%,
    rgba(7,13,8,0.55) 40%,
    rgba(7,13,8,0.82) 80%,
    rgba(7,13,8,1) 100%
  );
}
.hero-content {
  position:relative; z-index:4;
  max-width:860px; padding:0 2rem;
}
.hero-greeting {
  font-family:'Cinzel',serif; font-size:0.8rem;
  letter-spacing:0.4em; color:var(--gold); text-transform:uppercase;
  margin-bottom:1.25rem;
}
.hero-title {
  font-family:'Cinzel Decorative',serif;
  font-size:clamp(2.8rem,7vw,5.5rem);
  font-weight:900; line-height:1.1;
  color:var(--parchment);
  text-shadow:0 0 40px rgba(201,168,76,0.35),0 4px 20px rgba(0,0,0,0.6);
  margin-bottom:1.5rem;
}
.hero-divider {
  display:flex; align-items:center;
  justify-content:center; gap:1rem;
  margin-bottom:1.5rem;
}
.divider-line {
  display:block; width:100px; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.divider-gem { color:var(--gold); font-size:0.85rem; }
.hero-subtitle {
  font-family:'Cinzel',serif;
  font-size:clamp(1rem,2.5vw,1.5rem);
  font-weight:400; color:var(--gold-light);
  letter-spacing:0.08em; margin-bottom:1.75rem; min-height:2em;
}
.cursor-blink {
  animation:blink 1s step-end infinite;
  color:var(--gold);
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.hero-desc {
  font-size:1.05rem; line-height:1.9;
  color:var(--text-dim); max-width:600px;
  margin:0 auto 2.5rem; font-style:italic;
}
.hero-buttons { display:flex; gap:1.25rem; justify-content:center; flex-wrap:wrap; }

/* --- BUTTONS --- */
.btn {
  position:relative; display:inline-flex;
  align-items:center; gap:0.6rem;
  padding:0.85rem 2rem; border-radius:6px;
  font-family:'Cinzel',serif; font-size:0.82rem;
  font-weight:600; letter-spacing:0.1em; text-transform:uppercase;
  cursor:none; overflow:hidden;
  transition:all var(--transition);
}
.btn-glow {
  position:absolute; inset:0;
  background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,0.1) 50%,transparent 70%);
  transform:translateX(-100%);
  transition:transform 0.6s ease;
}
.btn:hover .btn-glow { transform:translateX(100%); }
.btn-gold {
  background:linear-gradient(135deg,var(--gold-dim),var(--gold));
  color:#0a1208; border:none;
  box-shadow:0 4px 20px rgba(201,168,76,0.3);
}
.btn-gold:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(201,168,76,0.5);
}
.btn-outline-gold {
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold);
}
.btn-outline-gold:hover {
  background:rgba(201,168,76,0.1);
  transform:translateY(-2px);
  box-shadow:var(--glow-gold);
}
.btn-sm { padding:0.6rem 1.4rem; font-size:0.75rem; }

/* --- SCROLL INDICATOR --- */
.scroll-indicator {
  position:absolute; bottom:2.5rem; left:50%;
  transform:translateX(-50%); z-index:4;
  text-align:center; animation:floatBob 3s ease-in-out infinite;
}
.scroll-indicator a {
  display:flex; flex-direction:column;
  align-items:center; gap:0.5rem;
  color:var(--text-dim); font-family:'Cinzel',serif;
  font-size:0.7rem; letter-spacing:0.2em;
}
.scroll-mouse {
  width:24px; height:38px; border:1.5px solid var(--gold);
  border-radius:12px; display:flex;
  justify-content:center; padding-top:6px;
}
.scroll-wheel {
  width:4px; height:8px;
  background:var(--gold); border-radius:2px;
  animation:scrollAnim 2s ease-in-out infinite;
}
@keyframes scrollAnim {
  0%   { transform:translateY(0); opacity:1; }
  100% { transform:translateY(14px); opacity:0; }
}
@keyframes floatBob {
  0%,100% { transform:translateX(-50%) translateY(0); }
  50%      { transform:translateX(-50%) translateY(-8px); }
}

/* =========================================================
   ABOUT
   ========================================================= */
.about-section { background:var(--bg); }
.about-grid {
  display:grid; grid-template-columns:1fr 1.4fr;
  gap:5rem; align-items:center;
}
.about-image-wrapper {
  position:relative;
  display:flex; justify-content:center;
}

/* === CIRCULAR PROFILE WITH GOLDEN RAYS === */
.about-image-frame {
  position:relative;
  width:320px; height:320px;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
}

/* Rotating golden rays */
.about-image-frame::before {
  content:'';
  position:absolute;
  inset:-18px;
  border-radius:50%;
  background:conic-gradient(
    from 0deg,
    transparent 0deg,
    rgba(201,168,76,0.55) 8deg,
    transparent 16deg,
    transparent 28deg,
    rgba(201,168,76,0.35) 36deg,
    transparent 44deg,
    transparent 56deg,
    rgba(201,168,76,0.55) 64deg,
    transparent 72deg,
    transparent 84deg,
    rgba(201,168,76,0.35) 92deg,
    transparent 100deg,
    transparent 112deg,
    rgba(201,168,76,0.55) 120deg,
    transparent 128deg,
    transparent 140deg,
    rgba(201,168,76,0.35) 148deg,
    transparent 156deg,
    transparent 168deg,
    rgba(201,168,76,0.55) 176deg,
    transparent 184deg,
    transparent 196deg,
    rgba(201,168,76,0.35) 204deg,
    transparent 212deg,
    transparent 224deg,
    rgba(201,168,76,0.55) 232deg,
    transparent 240deg,
    transparent 252deg,
    rgba(201,168,76,0.35) 260deg,
    transparent 268deg,
    transparent 280deg,
    rgba(201,168,76,0.55) 288deg,
    transparent 296deg,
    transparent 308deg,
    rgba(201,168,76,0.35) 316deg,
    transparent 324deg,
    transparent 336deg,
    rgba(201,168,76,0.55) 344deg,
    transparent 352deg,
    transparent 360deg
  );
  animation:raysRotate 12s linear infinite;
  z-index:0;
}

/* Outer glow ring */
.about-image-frame::after {
  content:'';
  position:absolute;
  inset:-6px;
  border-radius:50%;
  background:transparent;
  border:2px solid rgba(201,168,76,0.5);
  box-shadow:
    0 0 20px rgba(201,168,76,0.4),
    0 0 50px rgba(201,168,76,0.2),
    0 0 90px rgba(201,168,76,0.1),
    inset 0 0 20px rgba(201,168,76,0.1);
  animation:ringPulse 3s ease-in-out infinite;
  z-index:2;
}

@keyframes raysRotate {
  from { transform:rotate(0deg); }
  to   { transform:rotate(360deg); }
}

.profile-img {
  width:300px; height:300px;
  border-radius:50%;
  object-fit:cover;
  object-position:center top;
  position:relative; z-index:1;
  border:3px solid rgba(201,168,76,0.6);
  filter:sepia(10%) contrast(1.05) brightness(1.02);
  box-shadow:
    0 0 30px rgba(201,168,76,0.3),
    0 0 60px rgba(201,168,76,0.15);
}

/* Hide old corner elements */
.frame-corner { display:none; }

.image-glow-ring {
  position:absolute; inset:-28px; border-radius:50%;
  border:1px solid rgba(201,168,76,0.12);
  animation:ringPulse 5s ease-in-out infinite 1.5s;
  z-index:0;
}
@keyframes ringPulse {
  0%,100% { box-shadow:0 0 15px rgba(201,168,76,0.1); }
  50%      { box-shadow:0 0 35px rgba(201,168,76,0.25); }
}
.floating-runes { position:absolute; inset:0; pointer-events:none; }
.rune {
  position:absolute; color:var(--gold); font-size:1.2rem; opacity:0.5;
  animation:runeOrbit 6s ease-in-out infinite;
}
.r1 { top:-15px; left:20%; animation-delay:0s; }
.r2 { top:20%; right:-15px; animation-delay:1.5s; }
.r3 { bottom:-15px; right:25%; animation-delay:3s; }
.r4 { bottom:20%; left:-15px; animation-delay:4.5s; }
@keyframes runeOrbit {
  0%,100% { transform:translateY(0) rotate(0deg); opacity:0.4; }
  50%      { transform:translateY(-8px) rotate(180deg); opacity:0.8; }
}
.about-subtitle {
  font-family:'Cinzel',serif; font-size:1.2rem;
  color:var(--gold-light); margin-bottom:1.5rem; line-height:1.5;
}
.about-text p {
  line-height:1.9; color:var(--text-dim);
  margin-bottom:1rem; font-size:0.97rem;
}
.about-stats {
  display:flex; gap:2rem; margin-top:2rem;
  padding-top:2rem; border-top:1px solid var(--border);
}
.stat-item {
  display:flex; flex-direction:column;
  align-items:center; gap:0.5rem;
}
.stat-icon {
  width:44px; height:44px; border-radius:50%;
  background:rgba(201,168,76,0.08);
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1rem;
  transition:all var(--transition);
}
.stat-item:hover .stat-icon {
  background:rgba(201,168,76,0.15);
  box-shadow:var(--glow-gold);
}
.stat-label {
  font-family:'Cinzel',serif; font-size:0.7rem;
  letter-spacing:0.1em; color:var(--text-dim);
  text-transform:uppercase;
}

/* =========================================================
   SKILLS
   ========================================================= */
.skills-section {
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);
}
.skills-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:1.5rem;
}
.skill-card {
  position:relative; border-radius:var(--radius);
  background:var(--surface);
  border:1px solid var(--border);
  padding:2.5rem 2rem;
  backdrop-filter:blur(12px);
  transition:all var(--transition); overflow:hidden;
}
.skill-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0; transition:opacity var(--transition);
}
.skill-card:hover { border-color:var(--border-hv); transform:translateY(-6px); }
.skill-card:hover::before { opacity:1; }
.skill-card-glow {
  position:absolute; top:-40%; left:-40%;
  width:180%; height:180%;
  background:radial-gradient(ellipse,rgba(201,168,76,0.07) 0%,transparent 60%);
  pointer-events:none; opacity:0;
  transition:opacity var(--transition);
}
.skill-card:hover .skill-card-glow { opacity:1; }
.skill-icon-wrap {
  width:56px; height:56px; border-radius:50%;
  background:rgba(201,168,76,0.08);
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1.35rem;
  margin-bottom:1.25rem;
  transition:all var(--transition);
}
.skill-card:hover .skill-icon-wrap {
  background:rgba(201,168,76,0.15);
  box-shadow:var(--glow-gold);
}
.skill-card h3 {
  font-family:'Cinzel',serif; font-size:1rem;
  color:var(--parchment); margin-bottom:1.25rem;
}
.skill-list li {
  display:flex; align-items:center; gap:0.75rem;
  color:var(--text-dim); font-size:0.9rem;
  padding:0.45rem 0; border-bottom:1px solid rgba(201,168,76,0.05);
  transition:color var(--transition);
}
.skill-list li:last-child { border-bottom:none; }
.skill-list li:hover { color:var(--gold-light); }
.skill-list li i { color:var(--gold); width:16px; font-size:0.9rem; }
/* =========================================================
   PROJECTS
   ========================================================= */
.projects-section { background:var(--bg2); }
.projects-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:2rem;
}
.project-card {
  border-radius:var(--radius); overflow:hidden;
  background:var(--surface);
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  transition:all var(--transition);
}
.project-card:hover { transform:translateY(-8px); border-color:var(--border-hv); box-shadow:0 20px 50px rgba(0,0,0,0.5),var(--glow-gold); }
.project-img-wrap { position:relative; height:210px; overflow:hidden; }
.project-img { width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; }
.project-card:hover .project-img { transform:scale(1.08); }
.project-img-fallback {
  position:absolute; inset:0;
  background:linear-gradient(135deg,var(--bg3),var(--emerald));
  display:none; flex-direction:column;
  align-items:center; justify-content:center;
  gap:0.75rem; color:var(--gold);
  font-family:'Cinzel',serif; font-size:0.85rem;
}
.project-img-fallback.show { display:flex; }
.project-img-fallback i { font-size:2.5rem; opacity:0.7; }
.project-overlay {
  position:absolute; inset:0;
  background:rgba(7,13,8,0.85);
  display:flex; align-items:center; justify-content:center;
  opacity:0; transition:opacity var(--transition);
  backdrop-filter:blur(4px);
}
.project-card:hover .project-overlay { opacity:1; }
.project-overlay-links { display:flex; gap:1rem; }
.overlay-btn {
  display:flex; align-items:center; gap:0.5rem;
  padding:0.6rem 1.25rem;
  border:1px solid var(--gold); border-radius:6px;
  color:var(--gold); font-family:'Cinzel',serif;
  font-size:0.75rem; letter-spacing:0.08em;
  cursor:none; transition:all var(--transition);
}
.overlay-btn:hover { background:var(--gold); color:var(--bg); }
.project-body { padding:1.75rem; }
.project-body h3 {
  font-family:'Cinzel',serif; font-size:1rem;
  color:var(--parchment); margin-bottom:0.75rem;
}
.project-body p { color:var(--text-dim); font-size:0.88rem; line-height:1.75; margin-bottom:1.25rem; }
.project-tags { display:flex; flex-wrap:wrap; gap:0.5rem; }
.project-tags span {
  padding:0.3rem 0.85rem; border-radius:20px;
  background:rgba(201,168,76,0.07);
  border:1px solid var(--border);
  color:var(--gold); font-size:0.73rem;
  font-family:'Cinzel',serif; letter-spacing:0.05em;
}

/* =========================================================
   SERVICES
   ========================================================= */
.services-section { background:var(--bg); }
.services-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:2rem;
}
.service-card {
  position:relative; text-align:center;
  padding:3rem 2rem 2.5rem;
  border-radius:var(--radius);
  background:var(--surface);
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  overflow:hidden; transition:all var(--transition);
}
.service-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0; transition:opacity var(--transition);
}
.service-card:hover { border-color:var(--border-hv); transform:translateY(-6px); }
.service-card:hover::before { opacity:1; }
.service-card-glow {
  position:absolute; top:-50%; left:-50%;
  width:200%; height:200%;
  background:radial-gradient(ellipse,rgba(201,168,76,0.06) 0%,transparent 55%);
  pointer-events:none; opacity:0; transition:opacity var(--transition);
}
.service-card:hover .service-card-glow { opacity:1; }
.service-icon-wrap {
  width:68px; height:68px; border-radius:50%;
  background:rgba(201,168,76,0.08);
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1.6rem;
  margin:0 auto 1.5rem;
  transition:all var(--transition);
}
.service-card:hover .service-icon-wrap { box-shadow:var(--glow-gold); background:rgba(201,168,76,0.15); }
.service-card h3 { font-family:'Cinzel',serif; font-size:1.05rem; color:var(--parchment); margin-bottom:1rem; }
.service-card p { color:var(--text-dim); font-size:0.88rem; line-height:1.8; }
.service-rune {
  position:absolute; bottom:1rem; right:1.5rem;
  color:var(--gold); opacity:0.15; font-size:1.5rem;
}

/* =========================================================
   EXPERIENCE TIMELINE
   ========================================================= */
.experience-section { background:var(--bg2); }
.timeline { position:relative; max-width:800px; margin:0 auto; }
.timeline-line {
  position:absolute; left:50%; top:0; bottom:0;
  width:1px;
  background:linear-gradient(180deg,transparent,var(--gold-dim) 20%,var(--gold-dim) 80%,transparent);
  transform:translateX(-50%);
}
.timeline-item {
  position:relative; width:50%; margin-bottom:3.5rem;
}
.timeline-item:nth-child(even) {
  margin-left:50%; padding-left:3.5rem;
}
.timeline-item:nth-child(odd) {
  padding-right:3.5rem; text-align:right;
}
.timeline-marker {
  position:absolute; top:1.5rem;
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--bg3),var(--emerald));
  border:1px solid var(--gold-dim);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:0.9rem;
  box-shadow:var(--glow-sage);
  z-index:1;
}
.timeline-item:nth-child(odd) .timeline-marker {
  right:-22px;
}
.timeline-item:nth-child(even) .timeline-marker {
  left:-22px;
}
.marker-ring {
  position:absolute; inset:-6px; border-radius:50%;
  border:1px solid rgba(201,168,76,0.2);
  animation:ringPulse 3s ease-in-out infinite;
}
.timeline-card {
  padding:1.75rem; border-radius:var(--radius);
  background:var(--surface);
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  transition:all var(--transition);
}
.timeline-card:hover { border-color:var(--border-hv); box-shadow:0 10px 30px rgba(0,0,0,0.4); }
.timeline-date {
  font-family:'Cinzel',serif; font-size:0.7rem;
  color:var(--gold); letter-spacing:0.15em;
  text-transform:uppercase;
}
.timeline-card h3 {
  font-family:'Cinzel',serif; font-size:0.95rem;
  color:var(--parchment); margin:0.5rem 0 0.25rem;
}
.timeline-card h4 { font-size:0.82rem; color:var(--sage-light); margin-bottom:0.75rem; font-weight:400; }
.timeline-card ul li {
  font-size:0.84rem; color:var(--text-dim);
  line-height:1.7; padding:0.2rem 0;
}
.timeline-item:nth-child(odd) .timeline-card ul { text-align:right; }

/* =========================================================
   CAREER OBJECTIVE
   ========================================================= */
.objective-section {
  background:linear-gradient(135deg,var(--bg2) 0%,var(--bg3) 100%);
}
.objective-content {
  text-align:center; max-width:700px; margin:0 auto;
}
.objective-icon-wrap {
  position:relative; width:80px; height:80px;
  margin:0 auto 1.5rem;
  display:flex; align-items:center; justify-content:center;
}
.objective-icon-wrap i { font-size:2.5rem; color:var(--gold); position:relative; z-index:1; }
.objective-icon-glow {
  position:absolute; inset:-10px; border-radius:50%;
  background:radial-gradient(ellipse,rgba(201,168,76,0.2) 0%,transparent 70%);
  animation:ringPulse 4s ease-in-out infinite;
}
.objective-eyebrow {
  font-family:'Cinzel',serif; font-size:0.75rem;
  letter-spacing:0.35em; color:var(--gold); margin-bottom:0.75rem;
}
.objective-content h2 {
  font-family:'Cinzel',serif;
  font-size:clamp(1.8rem,3vw,2.5rem);
  color:var(--parchment); margin-bottom:2rem;
}
.objective-text {
  font-size:1.05rem; font-style:italic;
  line-height:2; color:var(--text-dim);
  border-left:2px solid var(--gold);
  padding:1rem 1.5rem; text-align:left;
  border-radius:0 var(--radius) var(--radius) 0;
  background:rgba(201,168,76,0.04);
  margin-bottom:2rem;
}
.objective-runes { color:var(--gold); letter-spacing:0.5rem; opacity:0.5; font-size:0.9rem; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-section { background:var(--bg); }
.contact-wrapper {
  display:grid; grid-template-columns:1fr 1.3fr;
  gap:4rem; align-items:start;
}
.contact-info h3 {
  font-family:'Cinzel',serif; font-size:1.2rem;
  color:var(--parchment); margin-bottom:1rem; line-height:1.4;
}
.contact-info > p { color:var(--text-dim); font-size:0.9rem; line-height:1.8; margin-bottom:2rem; }
.contact-details { display:flex; flex-direction:column; gap:1.25rem; margin-bottom:2.5rem; }
.contact-item { display:flex; align-items:center; gap:1rem; }
.contact-icon-wrap {
  width:48px; height:48px; border-radius:50%;
  background:rgba(201,168,76,0.08);
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1.1rem; flex-shrink:0;
  transition:all var(--transition);
}
.contact-item:hover .contact-icon-wrap { box-shadow:var(--glow-gold); background:rgba(201,168,76,0.15); }
.contact-text h4 { font-family:'Cinzel',serif; font-size:0.8rem; color:var(--gold); margin-bottom:0.2rem; letter-spacing:0.08em; }
.contact-text a { color:var(--text-dim); font-size:0.88rem; transition:color var(--transition); }
.contact-text a:hover { color:var(--gold-light); }
.social-links { display:flex; gap:1rem; }
.social-link {
  width:44px; height:44px; border-radius:50%;
  background:rgba(201,168,76,0.06);
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:1rem; cursor:none;
  transition:all var(--transition);
}
.social-link:hover { background:var(--gold); color:var(--bg); box-shadow:var(--glow-gold); }
.form-glow-border {
  border-radius:var(--radius);
  background:var(--surface);
  border:1px solid var(--border);
  backdrop-filter:blur(16px);
  padding:2.5rem;
  transition:border-color var(--transition);
}
.form-glow-border:hover { border-color:var(--border-hv); }
.contact-form { display:flex; flex-direction:column; gap:1.25rem; }
.form-group { position:relative; }
.form-group input,
.form-group textarea {
  width:100%; padding:1rem 1rem 0.5rem;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border); border-radius:6px;
  color:var(--text); font-family:'Lora',serif;
  font-size:0.9rem; outline:none; resize:vertical;
  transition:all var(--transition);
  appearance:none; -webkit-appearance:none;
}
.form-group input:focus,
.form-group textarea:focus { border-color:var(--gold); box-shadow:0 0 0 3px rgba(201,168,76,0.08); }
.form-group label {
  position:absolute; top:0.9rem; left:1rem;
  color:var(--text-dim); font-size:0.85rem;
  pointer-events:none; display:flex; align-items:center; gap:0.4rem;
  transition:all var(--transition);
}
.form-group input:not(:placeholder-shown) ~ label,
.form-group input:focus ~ label,
.form-group textarea:not(:placeholder-shown) ~ label,
.form-group textarea:focus ~ label {
  top:0.25rem; font-size:0.7rem; color:var(--gold);
}
.btn-submit { align-self:stretch; justify-content:center; margin-top:0.5rem; }
.form-message {
  margin-top:1rem; padding:0.75rem 1rem; border-radius:6px;
  font-size:0.85rem; text-align:center; display:none;
  font-family:'Cinzel',serif;
}
.form-message.success {
  display:block; color:#4caf50;
  background:rgba(76,175,80,0.1); border:1px solid rgba(76,175,80,0.25);
}
.form-message.error {
  display:block; color:#ef5350;
  background:rgba(239,83,80,0.1); border:1px solid rgba(239,83,80,0.25);
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer {
  position:relative; padding:3rem 0 2rem;
  background:var(--bg);
  border-top:1px solid var(--border); z-index:3;
}
.footer-magic-line {
  position:absolute; top:0; left:10%; right:10%;
  height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.footer-content {
  display:flex; flex-direction:column;
  align-items:center; gap:1rem; text-align:center;
  position:relative;
}
.footer-logo {
  font-family:'Cinzel Decorative',serif;
  font-size:1.1rem; display:flex; align-items:center; gap:0.4rem;
}
.footer-runes { color:var(--gold); letter-spacing:0.4rem; opacity:0.3; font-size:0.8rem; }
.copyright { color:var(--text-mute); font-size:0.8rem; font-family:'Cinzel',serif; letter-spacing:0.05em; }
.back-to-top {
  position:absolute; right:2rem; bottom:0;
  width:40px; height:40px; border-radius:50%;
  background:rgba(201,168,76,0.08);
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); cursor:none;
  transition:all var(--transition);
}
.back-to-top:hover { background:var(--gold); color:var(--bg); box-shadow:var(--glow-gold); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px) {
  .about-grid { grid-template-columns:1fr; gap:3rem; text-align:center; }
  .about-stats { justify-content:center; }
  .timeline-line { display:none; }
  .timeline-item { width:100%; margin-left:0 !important; padding:0 0 0 4rem !important; text-align:left !important; }
  .timeline-item:nth-child(odd) .timeline-marker,
  .timeline-item:nth-child(even) .timeline-marker { left:0; right:auto; }
  .timeline-item:nth-child(odd) .timeline-card ul { text-align:left; }
  .contact-wrapper { grid-template-columns:1fr; gap:3rem; }
}
@media (max-width:768px) {
  .mobile-menu-btn { display:flex; align-items:center; justify-content:center; }
  .nav-links {
    position:fixed; top:0; right:-100%; bottom:0; width:280px;
    background:rgba(7,13,8,0.97); backdrop-filter:blur(20px);
    flex-direction:column; padding:5rem 2rem 2rem;
    gap:1.5rem; border-left:1px solid var(--border);
    transition:right 0.4s cubic-bezier(0.4,0,0.2,1);
    z-index:999;
  }
  .nav-links.active { right:0; }
  .section { padding:5rem 0; }
  .hero-buttons { flex-direction:column; align-items:center; }
  .projects-grid, .services-grid { grid-template-columns:1fr; }
  .form-glow-border { padding:1.75rem; }
}
@media (max-width:480px) {
  .hero-title { font-size:2.4rem; }
  .about-stats { flex-direction:column; gap:1rem; }
  .skills-grid { grid-template-columns:1fr; }
}
