:root {
  --red:      #b22838;
  --red-dark: #8a1e2a;
  --red-lite: #d94058;
  --blush:    #fdf5f6;
  --petal:    #f9e8eb;
  --soft:     #f2c4cc;
  --white:    #ffffff;
  --ink:      #1e0f13;
  --muted:    #7a5560;
  --border:   #ecd5d9;
  --font-cursive: 'Pinyon Script', cursive;
  --font-body:    'Poppins', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{background:var(--white);color:var(--ink);font-family:var(--font-body);font-weight:300;line-height:1.6;overflow-x:hidden;}
::selection{background:var(--soft);color:var(--red-dark);}

/* ── NAV ── */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:300;height:66px;
  display:flex;align-items:center;justify-content:space-between;padding:0 4rem;
  background:rgba(255,255,255,0.96);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);transition:box-shadow 0.3s;
}
.nav.scrolled{box-shadow:0 4px 24px rgba(178,40,56,0.08);}
.nav-logo{font-family:var(--font-cursive);font-size:2rem;font-weight:400;color:var(--red);text-decoration:none;}
.nav-logo img {
    height: 40px;   /* adjust this */
    width: auto;
    object-fit: contain;
    display: block;
}
.nav-links{display:flex;align-items:center;gap:0.3rem;list-style:none;}
.nav-links a{font-size:0.72rem;font-weight:500;letter-spacing:0.09em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:0.4rem 0.85rem;border-radius:100px;transition:all 0.2s;}
.nav-links a:hover{color:var(--red);background:rgba(178,40,56,0.06);}
.nav-links a.active{color:var(--red);}
.nav-hire{background:var(--red)!important;color:var(--white)!important;box-shadow:0 4px 14px rgba(178,40,56,0.3);}
.nav-hire:hover{background:var(--red-dark)!important;transform:translateY(-1px);}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px;}
.burger span{display:block;width:22px;height:2px;background:var(--red);border-radius:2px;transition:all 0.25s;}
.mob-nav{display:none;position:fixed;top:66px;left:0;right:0;z-index:290;background:var(--white);border-bottom:1px solid var(--border);padding:1rem 2rem;flex-direction:column;box-shadow:0 8px 24px rgba(178,40,56,0.08);}
.mob-nav.open{display:flex;}
.mob-nav a{font-size:0.8rem;font-weight:500;letter-spacing:0.07em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:0.7rem 0;border-bottom:1px solid var(--petal);transition:color 0.2s;}
.mob-nav a:last-child{border-bottom:none;}
.mob-nav a:hover{color:var(--red);}

/* ── HERO ── */
#hero{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:110px 1.5rem 4rem;
  background:var(--white);
  position:relative;
  overflow:hidden;
}

/* decorative ribbon image */
.hero-bg-ribbon{
  position:absolute;
  top: 70px;
  right:20px;
  width:min(34vw, 360px);
  height:auto;
  object-fit:contain;
  opacity:0.42;
  pointer-events:none;
  z-index:0;
}

/* centered content a little lower */
.hero-content{
  position:relative;
  z-index:2;
  width:100%;
  max-width:520px;
  margin:0 auto;
  transform:translateY(34px);
}

.orb{
  position:absolute;
  border-radius:50%;
  pointer-events:none;
}

.orb-1{
  width:600px;
  height:600px;
  top:-200px;
  right:-200px;
  background:radial-gradient(circle,rgba(242,196,204,0.35) 0%,transparent 65%);
}

.orb-2{
  width:400px;
  height:400px;
  bottom:-120px;
  left:-100px;
  background:radial-gradient(circle,rgba(178,40,56,0.07) 0%,transparent 65%);
}

.orb-3{
  width:200px;
  height:200px;
  top:30%;
  left:5%;
  background:radial-gradient(circle,rgba(242,196,204,0.2) 0%,transparent 65%);
}

/* Pinyon Script hero name */
.hero-name{
  font-family:'Pinyon Script', cursive;
  font-size:clamp(4.3rem, 8vw, 7rem);
  font-weight:400;
  color:var(--red);
  line-height:0.95;
  margin-bottom:0.3rem;
  position:relative;
  z-index:1;
  opacity:0;
  animation:fadeUp 0.7s 0.15s forwards;
}

.hero-role{
  font-size:clamp(0.78rem, 1.5vw, 0.92rem);
  font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:0.75rem;
  position:relative;
  z-index:1;
  opacity:0;
  animation:fadeUp 0.7s 0.3s forwards;
}

.hero-desc{
  font-size:0.82rem;
  line-height:1.75;
  color:var(--muted);
  max-width:420px;
  margin:0 auto 0.95rem;
  position:relative;
  z-index:1;
  opacity:0;
  animation:fadeUp 0.7s 0.38s forwards;
}

.hero-loc{
  display:inline-flex;
  align-items:center;
  gap:0.35rem;
  font-size:0.72rem;
  font-weight:500;
  color:var(--muted);
  background:var(--petal);
  border:1px solid var(--soft);
  padding:0.32rem 0.9rem;
  border-radius:100px;
  margin-bottom:1.2rem;
  position:relative;
  z-index:1;
  opacity:0;
  animation:fadeUp 0.6s 0.46s forwards;
}

.hero-ribbon{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:0.8rem;
  margin-bottom:1.2rem;
  opacity:0;
  animation:fadeUp 0.6s 0.54s forwards;
  position:relative;
  z-index:1;
}

.rline{
  width:56px;
  height:1px;
  background:linear-gradient(to right,transparent,var(--soft));
}

.rline-r{
  background:linear-gradient(to left,transparent,var(--soft));
}

.hero-btns{
  display:flex;
  gap:0.7rem;
  flex-wrap:wrap;
  justify-content:center;
  position:relative;
  z-index:1;
  opacity:0;
  animation:fadeUp 0.6s 0.62s forwards;
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:0.35rem;
  padding:0.7rem 1.35rem;
  border-radius:100px;
  font-family:var(--font-body);
  font-size:0.68rem;
  font-weight:600;
  letter-spacing:0.09em;
  text-transform:uppercase;
  text-decoration:none;
  border:none;
  cursor:pointer;
  transition:all 0.22s;
}

.btn-primary{
  background:var(--red);
  color:var(--white);
  box-shadow:0 6px 22px rgba(178,40,56,0.3);
}

.btn-primary:hover{
  background:var(--red-dark);
  transform:translateY(-2px);
  box-shadow:0 10px 30px rgba(178,40,56,0.4);
}

.btn-ghost{
  background:transparent;
  color:var(--red);
  border:1.5px solid var(--soft);
}

.btn-ghost:hover{
  background:var(--petal);
  transform:translateY(-2px);
}

.scroll-hint{
  position:absolute;
  bottom:1.6rem;
  left:50%;
  transform:translateX(-50%);
  font-size:0.58rem;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--soft);
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:0.35rem;
  opacity:0;
  animation:fadeUp 0.6s 1.1s forwards;
  z-index:2;
}

.scroll-arrow{
  width:1px;
  height:24px;
  background:linear-gradient(to bottom,var(--soft),transparent);
}

/* responsive */
@media (max-width: 768px){
  #hero{
    padding:100px 1rem 4rem;
  }

  .hero-content{
    max-width:440px;
    transform:translateY(22px);
  }

  .hero-bg-ribbon{
    width:min(42vw, 220px);
    top:70;
    right:20px;
    opacity:0.3;
  }

  .hero-name{
    font-size:clamp(3.8rem, 12vw, 5.4rem);
  }

  .hero-role{
    font-size:0.74rem;
    letter-spacing:0.14em;
  }

  .hero-desc{
    font-size:0.78rem;
    max-width:360px;
  }

  .hero-loc{
    font-size:0.68rem;
  }

  .btn{
    padding:0.68rem 1.1rem;
    font-size:0.64rem;
  }

  .rline{
    width:42px;
  }
}

@media (max-width: 480px){
  .hero-content{
    transform:translateY(16px);
  }

  .hero-bg-ribbon{
    width:150px;
    top:8px;
    right:-22px;
    opacity:0.24;
  }

  .hero-btns{
    flex-direction:column;
    align-items:center;
  }

  .btn{
    width:100%;
    max-width:220px;
    justify-content:center;
  }

  .hero-desc{
    font-size:0.76rem;
  }
}
/* ── SECTIONS ── */
.sec{padding:6rem 4rem;}
.sec-alt{background:var(--blush);}
.sec-inner{max-width:1140px;margin:0 auto;}
.tag{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.62rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;color:var(--red);margin-bottom:0.9rem;}
.tag::before,.tag::after{content:'🎀';font-size:0.65rem;opacity:0.7;}
.sec-heading{font-family:var(--font-cursive);font-size:clamp(2.5rem,4vw,4rem);font-weight:400;color:var(--red);line-height:1.1;margin-bottom:0.5rem;}
.sec-sub{font-size:0.85rem;color:var(--muted);max-width:640px;line-height:1.8;margin-bottom:3rem;}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;}
.about-card{background:var(--white);border-radius:20px;border:1px solid var(--border);padding:2.5rem;box-shadow:0 4px 24px rgba(178,40,56,0.06);}
.about-item{display:flex;gap:1rem;margin-bottom:1.4rem;padding-bottom:1.4rem;border-bottom:1px solid var(--petal);}
.about-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none;}
.about-icon{font-size:1.2rem;flex-shrink:0;width:36px;height:36px;background:var(--petal);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-top:0.1rem;}
.about-item-title{font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);margin-bottom:0.3rem;}
.about-item-text{font-size:0.83rem;color:var(--muted);line-height:1.75;}
.about-item-text strong{color:var(--ink);font-weight:600;}
.skills-panel{display:flex;flex-direction:column;gap:1.5rem;}
.skill-group-title{font-size:0.62rem;font-weight:700;letter-spacing:0.15em;text-transform:uppercase;color:var(--red);margin-bottom:0.7rem;display:flex;align-items:center;gap:0.5rem;}
.skill-group-title::after{content:'';flex:1;height:1px;background:var(--border);}
.skill-chips{display:flex;flex-wrap:wrap;gap:0.35rem;}
.chip{font-size:0.7rem;padding:0.3rem 0.75rem;background:var(--white);border:1px solid var(--border);border-radius:100px;color:var(--muted);transition:all 0.18s;cursor:default;}
.chip:hover{border-color:var(--red);color:var(--red);background:rgba(178,40,56,0.04);}

/* ── TIMELINE ── */
.timeline{position:relative;padding-left:2rem;}
.timeline::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--soft),var(--border),var(--petal));}
.tl-item{position:relative;padding:0 0 3rem 2.5rem;opacity:0;transform:translateX(-16px);transition:opacity 0.5s,transform 0.5s;}
.tl-item.visible{opacity:1;transform:none;}
.tl-item:last-child{padding-bottom:0;}
.tl-dot{position:absolute;left:-2.4rem;top:0.35rem;width:14px;height:14px;border-radius:50%;background:var(--red);border:3px solid var(--white);box-shadow:0 0 0 2px var(--soft);}
.tl-dot.current{background:var(--white);border-color:var(--red);animation:ping 2s infinite;}
@keyframes ping{0%{box-shadow:0 0 0 3px rgba(178,40,56,0.2);}60%{box-shadow:0 0 0 8px rgba(178,40,56,0);}100%{box-shadow:0 0 0 3px rgba(178,40,56,0.2);}}
.tl-period{font-size:0.65rem;font-weight:600;letter-spacing:0.1em;color:var(--red);text-transform:uppercase;margin-bottom:0.3rem;}
.tl-company{font-family:var(--font-cursive);font-size:1.8rem;font-weight:400;color:var(--ink);line-height:1.1;margin-bottom:0.2rem;}
.tl-role{font-size:0.67rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--red);opacity:0.75;margin-bottom:0.25rem;}
.tl-loc{display:inline-flex;align-items:center;gap:0.3rem;font-size:0.62rem;background:var(--petal);color:var(--muted);padding:0.15rem 0.6rem;border-radius:100px;border:1px solid var(--border);margin-bottom:0.9rem;margin-top:0.3rem;font-weight:500;}
.tl-bullets{list-style:none;}
.tl-bullets li{font-size:0.82rem;color:var(--muted);line-height:1.7;padding:0.22rem 0 0.22rem 1.3rem;position:relative;}
.tl-bullets li::before{content:'✦';position:absolute;left:0;color:var(--soft);font-size:0.5rem;top:0.55em;}

/* ═══════════════════════════════════════
   PROJECTS
═══════════════════════════════════════ */

/* ── SIGMA — FULL WIDTH FEATURED ── */
.proj-featured{
  background:var(--white);border:1px solid var(--border);border-radius:24px;
  overflow:hidden;margin-bottom:1.4rem;
  opacity:0;transform:translateY(18px);
  transition:opacity 0.5s,transform 0.5s,box-shadow 0.25s,border-color 0.25s;
  box-shadow:0 4px 24px rgba(178,40,56,0.06);
}
.proj-featured.visible{opacity:1;transform:none;}
.proj-featured:hover{border-color:var(--soft);box-shadow:0 20px 60px rgba(178,40,56,0.14);}

/* Featured header — spans full width, 2-col layout inside */
.proj-feat-header{
  background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);
  padding:2.5rem 3rem;
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center;
  position:relative;overflow:hidden;
}
.proj-feat-header::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(255,255,255,0.07) 1px,transparent 1px);
  background-size:16px 16px;pointer-events:none;
}
.pfh-left{position:relative;z-index:1;}
.pfh-tag{
  font-size:0.6rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;
  background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.25);
  color:var(--white);padding:0.25rem 0.7rem;border-radius:100px;
  display:inline-block;margin-bottom:0.8rem;
}
.pfh-label{font-size:0.62rem;color:rgba(255,255,255,0.55);letter-spacing:0.12em;text-transform:uppercase;font-weight:500;margin-bottom:0.3rem;}
.pfh-name{font-family:var(--font-cursive);font-size:clamp(2.2rem,4vw,3.2rem);font-weight:400;color:var(--white);line-height:1.1;margin-bottom:0.4rem;}
.pfh-sub{font-size:0.82rem;color:rgba(255,255,255,0.65);font-style:italic;}
.pfh-right{
  position:relative;z-index:1;
  display:flex;flex-direction:column;gap:0.6rem;align-items:flex-end;
}
.pfh-badge{
  display:inline-flex;align-items:center;gap:0.45rem;
  background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);
  padding:0.45rem 1rem;border-radius:100px;
  font-size:0.68rem;font-weight:600;color:var(--white);letter-spacing:0.07em;
}
.pfh-bow{font-size:2.5rem;opacity:0.5;}

/* Featured body — 3-col sub-projects + STAR side-by-side */
.proj-feat-body{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
}
.feat-star{
  padding:2.5rem 3rem;border-right:1px solid var(--border);
}
.feat-sub-projects{
  padding:2.5rem 2.5rem;
  background:var(--blush);
}
.feat-star-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:0.7rem;margin-bottom:1.2rem;
}
.star-block{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:0.75rem 0.9rem;}
.star-lbl{font-size:0.56rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--red);margin-bottom:0.28rem;display:flex;align-items:center;gap:0.3rem;}
.star-icon{width:15px;height:15px;border-radius:50%;background:var(--red);color:var(--white);font-size:0.48rem;display:inline-flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0;}
.star-text{font-size:0.74rem;color:var(--muted);line-height:1.55;}
.star-result{grid-column:1/-1;}
.star-result .star-block{background:rgba(178,40,56,0.04);border-color:rgba(178,40,56,0.18);}
.star-result .star-icon{background:var(--red-lite);}
.star-result .star-text{color:var(--ink);}

/* Sub-projects panel */
.sub-title{font-size:0.62rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--red);margin-bottom:1.2rem;}
.sub-card{
  background:var(--white);border:1px solid var(--border);border-radius:12px;
  padding:1rem 1.1rem;margin-bottom:0.8rem;
  transition:border-color 0.2s,box-shadow 0.2s;
}
.sub-card:last-child{margin-bottom:0;}
.sub-card:hover{border-color:var(--soft);box-shadow:0 4px 16px rgba(178,40,56,0.08);}
.sub-card-head{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.4rem;}
.sub-card-dot{width:8px;height:8px;border-radius:50%;background:var(--red);flex-shrink:0;}
.sub-card-name{font-size:0.78rem;font-weight:600;color:var(--ink);}
.sub-card-result{font-size:0.72rem;color:var(--muted);line-height:1.55;}

/* Featured tools strip */
.feat-tools{
  padding:1rem 3rem;border-top:1px solid var(--border);
  display:flex;gap:0.4rem;flex-wrap:wrap;align-items:center;
}
.feat-tools-label{font-size:0.58rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-right:0.3rem;}
.ptool{font-size:0.62rem;padding:0.16rem 0.5rem;background:var(--petal);color:var(--muted);border-radius:4px;border:1px solid var(--border);}

/* ── REGULAR PROJECTS — 2 per row ── */
.proj-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem;}
.proj-card{
  background:var(--white);border:1px solid var(--border);border-radius:20px;
  overflow:hidden;
  opacity:0;transform:translateY(18px);
  transition:opacity 0.45s,transform 0.45s,box-shadow 0.22s,border-color 0.22s;
}
.proj-card.visible{opacity:1;transform:none;}
.proj-card:hover{border-color:var(--soft);box-shadow:0 16px 48px rgba(178,40,56,0.12);transform:translateY(-5px);}
.proj-head{background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);padding:1.4rem 1.6rem;position:relative;overflow:hidden;}
.proj-head::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,0.08) 1px,transparent 1px);background-size:14px 14px;pointer-events:none;}
.proj-head-row{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:1;}
.proj-tag-pill{font-size:0.58rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.25);color:var(--white);padding:0.22rem 0.6rem;border-radius:100px;}
.proj-bow-icon{font-size:1rem;opacity:0.65;}
.proj-name{font-family:var(--font-cursive);font-size:1.6rem;font-weight:400;color:var(--white);margin-top:0.7rem;line-height:1.2;position:relative;z-index:1;}
.proj-sub-name{font-size:0.7rem;color:rgba(255,255,255,0.6);margin-top:0.2rem;position:relative;z-index:1;font-style:italic;}
.proj-body{padding:1.4rem 1.6rem;}
.proj-star-grid{display:grid;grid-template-columns:1fr 1fr;gap:0.7rem;margin-bottom:1.1rem;}
.proj-star-result{grid-column:1/-1;}
.proj-tools{display:flex;flex-wrap:wrap;gap:0.3rem;}

/* ═══════════════════════════════════════
   CONTACT — ENVELOPE
═══════════════════════════════════════ */
#contact{
  background:linear-gradient(145deg,#2a0d16 0%,#1a0a10 100%);
  padding:6rem 1.5rem;
  position:relative;
  overflow:hidden;
}

#contact::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:radial-gradient(circle,rgba(242,196,204,0.06) 1px,transparent 1px);
  background-size:22px 22px;
  pointer-events:none;
}

#contact .c-orb1{
  position:absolute;
  width:400px;
  height:400px;
  border-radius:50%;
  top:-100px;
  right:-100px;
  background:radial-gradient(circle,rgba(178,40,56,0.15) 0%,transparent 65%);
  pointer-events:none;
}

#contact .c-orb2{
  position:absolute;
  width:300px;
  height:300px;
  border-radius:50%;
  bottom:-80px;
  left:-80px;
  background:radial-gradient(circle,rgba(242,196,204,0.08) 0%,transparent 65%);
  pointer-events:none;
}

.contact-inner{
  max-width:760px;
  margin:0 auto;
  text-align:center;
  position:relative;
  z-index:1;
}

.contact-heading{
  font-family:'Pinyon Script', cursive;
  font-size:clamp(2.8rem,5vw,4.5rem);
  font-weight:400;
  color:var(--soft);
  margin-bottom:0.3rem;
  line-height:1;
}

.contact-sub-text{
  font-size:0.78rem;
  color:rgba(255,255,255,0.55);
  letter-spacing:0.12em;
  text-transform:uppercase;
  margin-bottom:2.2rem;
}

/* Envelope shell */
.envelope{
  position:relative;
  max-width:680px;
  margin:0 auto;
  background:#fff9fb;
  border-radius:14px;
  box-shadow:
    0 28px 70px rgba(0,0,0,0.38),
    0 8px 24px rgba(0,0,0,0.22);
  overflow:hidden;
  isolation:isolate;
}

/* top flap */
.envelope::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:140px;
  background:#efd4da;
  clip-path:polygon(0 0,100% 0,50% 100%);
  z-index:3;
  pointer-events:none;
}

/* bottom fold */
.envelope::after{
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  width:100%;
  height:120px;
  background:#f6e7ea;
  clip-path:polygon(0 100%,50% 0,100% 100%);
  z-index:1;
  pointer-events:none;
}

/* side folds */
.env-left,
.env-right{
  position:absolute;
  top:110px;
  bottom:0;
  width:22%;
  background:#f3e1e5;
  z-index:1;
  pointer-events:none;
}

.env-left{
  left:0;
  clip-path:polygon(0 0,100% 50%,0 100%);
}

.env-right{
  right:0;
  clip-path:polygon(100% 0,0 50%,100% 100%);
}

/* inner card / letter */
.envelope-inner{
  position:relative;
  z-index:2;
  background:var(--white);
  margin:110px 28px 28px;
  padding:2rem 1.5rem 1.5rem;
  border-radius:12px;
  box-shadow:0 10px 30px rgba(42,21,32,0.08);
  text-align:left;
}

/* form */
#cForm{
  position:relative;
  z-index:2;
}

.efg{
  display:flex;
  flex-direction:column;
  gap:0.35rem;
  margin-bottom:0.95rem;
}

.efg label{
  font-size:0.62rem;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--muted);
}

.efg input,
.efg textarea,
.efg select{
  font-family:'Poppins',sans-serif;
  font-size:0.82rem;
  font-weight:300;
  padding:0.72rem 0.95rem;
  border:1px solid var(--soft);
  border-radius:10px;
  background:var(--blush);
  color:var(--ink);
  outline:none;
  width:100%;
  transition:border-color 0.2s,box-shadow 0.2s,background 0.2s;
}

.efg input:focus,
.efg textarea:focus,
.efg select:focus{
  border-color:var(--red);
  box-shadow:0 0 0 3px rgba(178,40,56,0.1);
  background:var(--white);
}

.efg textarea{
  resize:vertical;
  min-height:110px;
}

.eform-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0.9rem;
}

/* hidden honeypot */
.hp{
  position:absolute;
  left:-9999px;
  opacity:0;
  pointer-events:none;
}

/* button */
.form-btn{
  width:100%;
  padding:0.9rem 1rem;
  border:none;
  border-radius:999px;
  background:var(--red);
  color:var(--white);
  font-family:'Poppins',sans-serif;
  font-size:0.78rem;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 8px 22px rgba(188,0,62,0.24);
  transition:transform 0.2s, box-shadow 0.2s, background 0.2s;
}

.form-btn:hover{
  background:#9a0033;
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(188,0,62,0.3);
}

.form-note{
  text-align:center;
  font-size:0.68rem;
  color:var(--muted);
  margin-top:0.9rem;
  line-height:1.6;
}

/* success message */
.form-success{
  display:none;
  text-align:center;
  padding:2rem 1rem;
  position:relative;
  z-index:2;
}

.form-success.show{
  display:block;
}

.fs-bow{
  display:block;
  font-size:1.6rem;
  margin-bottom:0.6rem;
}

.fs-title{
  font-family:'Playfair Display',serif;
  font-size:1.35rem;
  color:var(--red);
  margin-bottom:0.35rem;
}

.fs-sub{
  font-size:0.85rem;
  color:var(--muted);
  line-height:1.7;
  max-width:420px;
  margin:0 auto;
}

/* links under envelope */
.contact-links-row{
  display:flex;
  justify-content:center;
  gap:0.8rem;
  flex-wrap:wrap;
  margin-top:1.5rem;
}

.c-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:0.7rem 1.2rem;
  border:1px solid rgba(255,255,255,0.12);
  border-radius:999px;
  text-decoration:none;
  color:rgba(255,255,255,0.88);
  background:rgba(255,255,255,0.05);
  font-size:0.75rem;
  transition:all 0.2s ease;
}

.c-link:hover{
  transform:translateY(-2px);
  border-color:rgba(255,255,255,0.22);
  background:rgba(255,255,255,0.1);
}

.avail{
  margin-top:1rem;
  display:inline-flex;
  align-items:center;
  gap:0.5rem;
  padding:0.55rem 1rem;
  border-radius:999px;
  background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);
  color:rgba(255,255,255,0.78);
  font-size:0.7rem;
}

.dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#22c55e;
  display:inline-block;
}

/* responsive */
@media (max-width: 768px){
  #contact{
    padding:5rem 1rem;
  }

  .envelope-inner{
    margin:90px 16px 16px;
    padding:1.5rem 1rem 1rem;
  }

  .envelope::before{
    height:110px;
  }

  .env-left,
  .env-right{
    top:90px;
    width:18%;
  }

  .eform-row{
    grid-template-columns:1fr;
    gap:0;
  }

  .contact-links-row{
    flex-direction:column;
    align-items:center;
  }

  .c-link{
    width:100%;
    max-width:320px;
  }
}

@media (max-width: 480px){
  .contact-heading{
    font-size:2.4rem;
  }

  .contact-sub-text{
    font-size:0.72rem;
    letter-spacing:0.08em;
  }

  .envelope-inner{
    margin:80px 12px 12px;
  }

  .envelope::before{
    height:95px;
  }

  .env-left,
  .env-right{
    top:80px;
    width:16%;
  }
}

/* Honeypot */
.hp{position:absolute;left:-9999px;opacity:0;pointer-events:none;}

.form-btn{
  width:100%;margin-top:0.4rem;padding:0.85rem;border-radius:100px;
  background:var(--red);color:var(--white);
  font-family:var(--font-body);font-size:0.73rem;font-weight:600;
  letter-spacing:0.1em;text-transform:uppercase;
  border:none;cursor:pointer;
  box-shadow:0 6px 22px rgba(178,40,56,0.3);
  transition:all 0.22s;
}
.form-btn:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 10px 30px rgba(178,40,56,0.4);}
.form-note{text-align:center;font-size:0.62rem;color:var(--muted);margin-top:0.7rem;line-height:1.6;}

/* Success */
.form-success{display:none;text-align:center;padding:2rem 1rem;}
.form-success.show{display:block;}
.fs-bow{font-size:2.5rem;display:block;margin-bottom:0.8rem;}
.fs-title{font-family:var(--font-cursive);font-size:2rem;color:var(--red);font-weight:400;margin-bottom:0.4rem;}
.fs-sub{font-size:0.82rem;color:var(--muted);}

/* Bottom links */
.contact-links-row{
  display:flex;justify-content:center;gap:0.8rem;flex-wrap:wrap;margin-top:2rem;
}
.c-link{
  display:inline-flex;align-items:center;gap:0.4rem;
  padding:0.55rem 1.3rem;border:1px solid rgba(255,255,255,0.12);
  border-radius:100px;color:rgba(255,255,255,0.6);text-decoration:none;
  font-size:0.72rem;font-weight:500;
  transition:all 0.2s;
  background:rgba(255,255,255,0.04);
}
.c-link:hover{border-color:var(--soft);color:var(--white);background:rgba(255,255,255,0.08);}
.avail{
  margin-top:1.2rem;display:inline-flex;align-items:center;gap:0.5rem;
  background:rgba(255,255,255,0.06);padding:0.45rem 1.1rem;border-radius:100px;
  border:1px solid rgba(255,255,255,0.1);
  font-size:0.65rem;color:rgba(255,255,255,0.45);font-weight:500;
}
.dot{width:7px;height:7px;border-radius:50%;background:#22c55e;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}

/* ── FOOTER ── */
footer{background:#110609;text-align:center;padding:1.8rem 2rem;}
.footer-logo{font-family:var(--font-cursive);font-size:1.6rem;color:var(--soft);font-weight:400;display:block;margin-bottom:0.35rem;}
.footer-copy{font-size:0.63rem;color:white;letter-spacing:0.08em;}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px);}to{opacity:1;transform:none;}}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .nav{padding:0 1.5rem;}
  .nav-links{display:none;}
  .burger{display:flex;}
  .sec{padding:4rem 1.5rem;}
  #hero{padding:90px 1.5rem 3rem;}
  .about-grid{grid-template-columns:1fr;gap:2.5rem;}
  .proj-feat-body{grid-template-columns:1fr;}
  .feat-star{border-right:none;border-bottom:1px solid var(--border);padding:2rem 1.5rem;}
  .feat-sub-projects{padding:2rem 1.5rem;}
  .proj-feat-header{grid-template-columns:1fr;padding:2rem 1.5rem;}
  .pfh-right{align-items:flex-start;flex-direction:row;flex-wrap:wrap;}
  .feat-tools{padding:1rem 1.5rem;}
  .feat-star-grid{grid-template-columns:1fr;}
  .star-result{grid-column:auto;}
  .proj-grid{grid-template-columns:1fr;}
  .proj-star-grid{grid-template-columns:1fr;}
  .proj-star-result{grid-column:auto;}
  .timeline{padding-left:1.2rem;}
  .tl-item{padding-left:2rem;}
  .tl-dot{left:-1.7rem;}
  .envelope::before{border-left-width:50vw;border-right-width:50vw;}
  .envelope::after{border-left-width:50vw;border-right-width:50vw;}
  .env-left,.env-right{display:none;}
  .eform-row{grid-template-columns:1fr;}
}
@media(max-width:540px){
  .hero-name{font-size:3.5rem;}
  .envelope-inner{padding:2rem 1.2rem 1.5rem;}
}