/* ===== Anchor & smooth scroll ===== */
:root { --header-h: 72px; }
html { scroll-padding-top: var(--header-h); scroll-behavior: smooth; }
section { scroll-margin-top: var(--header-h); }

/* ===== Theme ===== */
:root{
  --bg:#0b0914; --card:rgba(25,19,44,.8); --muted:#a1a1b5; --text:#f1f1fa;
  --primary:#7c3aed; --primary-700:#6d28d9; --accent:#d946ef;
  --success:#22c55e; --warning:#f59e0b; --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Helvetica Neue,Arial;}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:100%;max-width:1200px;margin:0 auto;padding:0 clamp(16px,4vw,20px)}
@media (max-width:640px){.container{padding:0 16px}}
.grid{display:grid;gap:20px}
@media (max-width:640px){.grid{gap:16px}}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:.6rem;padding:clamp(0.85rem,2vw,1rem) clamp(1.2rem,3vw,1.4rem);border-radius:999px;
  font-weight:700;font-size:clamp(0.9rem,2vw,1rem);box-shadow:0 6px 20px rgba(124,58,237,.4);transition:transform .15s,box-shadow .2s,background .2s}
@media (max-width:640px){.btn{width:100%;justify-content:center}}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none}
.btn-primary:hover{box-shadow:0 0 18px rgba(180,70,255,.7)}
.btn-secondary{background:transparent;border:1px solid rgba(255,255,255,.15);color:#c7bdfd}
.btn-secondary:hover{background:rgba(124,58,237,.15)}

/* ===== Header / Nav ===== */
header.site{position:sticky;top:0;z-index:40;background:rgba(15,12,28,.7);
  backdrop-filter:saturate(150%) blur(14px);border-bottom:1px solid rgba(124,92,255,.3)}
header .nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:clamp(12px,2vw,14px) 0}
@media (max-width:640px){header .nav{padding:10px 0}}
header .nav.container{padding-left:clamp(20px,4vw,24px);padding-right:clamp(20px,4vw,24px)}
@media (max-width:640px){header .nav.container{padding-left:18px;padding-right:18px}}

.brand{display:flex;align-items:center;gap:clamp(0.5rem,1.5vw,0.6rem);font-family:'Poppins',sans-serif;font-weight:600;
  font-size:clamp(1.1rem,3.5vw,1.35rem);letter-spacing:.2px;color:#c3a9ff;line-height:1}
.brand:hover{color:#d8c5ff}
.logo-img{width:clamp(28px,4.2vw,40px);height:auto;display:block;flex-shrink:0}

.nav .links{display:flex;align-items:center;gap:1.2rem}
.nav .links a{opacity:.9;transition:opacity .2s,color .2s}
.nav .links a:hover{opacity:1;color:var(--accent)}

/* Mobile nav (checkbox hack) */
#nav-toggle{display:none}
.hamburger{display:none;width:42px;height:42px;border-radius:10px;align-items:center;justify-content:center;cursor:pointer;
  border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.02)}
.hamburger span{width:20px;height:2px;background:#eae7ff;display:block;margin:3px 0;transition:transform .18s,opacity .18s}
#nav-toggle:checked + .hamburger span:nth-child(1){transform:translateY(5px) rotate(45deg)}
#nav-toggle:checked + .hamburger span:nth-child(2){opacity:0}
#nav-toggle:checked + .hamburger span:nth-child(3){transform:translateY(-5px) rotate(-45deg)}

@media (max-width:920px){
  .nav{position:relative}
  .hamburger{display:inline-flex;flex-shrink:0}
  .nav .links{
    position:absolute;top:calc(100% + 8px);left:16px;right:16px;display:grid;gap:12px;padding:20px;
    background:rgba(15,12,28,.98);border:1px solid rgba(124,92,255,.3);border-radius:14px;
    box-shadow:0 14px 40px rgba(0,0,0,.45);opacity:0;visibility:hidden;transform:translateY(-8px);
    pointer-events:none;transition:opacity .18s,transform .18s,visibility .18s;z-index:50}
  #nav-toggle:checked ~ .links{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
  .nav .links a{padding:10px;text-align:center;border-radius:8px;transition:background .2s}
  .nav .links a:hover{background:rgba(124,92,255,.1)}
  .nav .links .btn{justify-content:center;width:100%;margin-top:4px}
}

/* ===== Hero ===== */
.hero{padding: clamp(24px,6vw,60px) 0 clamp(40px,10vw,88px);
  background:radial-gradient(circle at 70% 10%, rgba(124,58,237,.25), transparent 70%),
             radial-gradient(circle at 20% -10%, rgba(217,70,239,.2), transparent 60%)}
@media (max-width:640px){.hero{padding:24px 0 40px}}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap: clamp(20px,4vw,48px);align-items:center}
.hero h1{font-size:clamp(1.5rem,6.2vw,3.8rem);line-height:1.15;margin:0 0 clamp(14px,3vw,16px)}
@media (max-width:640px){.hero h1{margin:0 0 16px}}
.hero p{font-size:clamp(0.9rem,2.2vw,1.25rem);color:var(--muted);line-height:1.6;margin:0 0 clamp(20px,4vw,24px)}
@media (max-width:640px){.hero p{margin:0 0 24px}}
.hero-columns{width:100%;height:auto;border-radius:14px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.45))}
.cta-row{display:flex;gap:clamp(0.75rem,2vw,1rem);flex-wrap:wrap;margin-top:clamp(24px,4vw,32px)}
@media (max-width:640px){.cta-row{flex-direction:column;gap:14px;margin-top:28px}}
@media (max-width:1024px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-graphic{display:flex;justify-content:center;margin-top:32px}
  .hero-columns{max-width:min(560px,90%)}
}
@media (max-width:640px){.hero-graphic{margin-top:28px}}

/* Small helper pills */
.eyebrow{display:inline-flex;gap:clamp(0.4rem,1.5vw,0.5rem);flex-wrap:wrap;margin-bottom:clamp(16px,3vw,20px)}
@media (max-width:640px){.eyebrow{margin-bottom:18px}}
.pill{display:inline-flex;align-items:center;gap:.3rem;background:rgba(124,92,255,.12);
  border:1px solid rgba(124,92,255,.25);padding:clamp(0.3rem,1vw,0.35rem) clamp(0.5rem,1.5vw,0.6rem);border-radius:999px;
  font-weight:700;font-size:clamp(0.75rem,1.8vw,0.85rem)}
.pill .icon{font-size:clamp(0.85rem,2vw,1rem)}
.pill.web3{background:rgba(34,211,238,.12);border-color:rgba(34,211,238,.3)}
.stack{display:flex;flex-wrap:wrap;gap:clamp(0.4rem,1.2vw,0.5rem);margin-top:clamp(16px,3vw,20px)}
@media (max-width:640px){.stack{gap:0.4rem;margin-top:18px}}
.tag{display:inline-block;padding:clamp(0.25rem,0.8vw,0.35rem) clamp(0.5rem,1.2vw,0.7rem);border-radius:999px;font-weight:600;
  background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.3);color:#d4c2ff;
  font-size:clamp(0.7rem,1.6vw,0.8rem);line-height:1.3}
@media (max-width:640px){.tag{font-size:0.7rem;padding:0.25rem 0.5rem}}

/* ===== Sections & cards ===== */
section{padding:clamp(40px,8vw,80px) 0;border-top:1px solid rgba(124,92,255,.2)}
@media (max-width:640px){section{padding:36px 0}}
h2.section-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin:0 0 clamp(8px,2vw,10px);line-height:1.2}
p.section-kicker{color:#b7aefc;margin:0 0 clamp(20px,4vw,28px);font-weight:500;font-size:clamp(0.95rem,2vw,1rem);line-height:1.5}

.card{background:var(--card);border:1px solid rgba(124,92,255,.25);border-radius:var(--radius);
  padding:clamp(18px,3vw,24px);backdrop-filter:blur(8px);transition:transform .15s,box-shadow .2s}
@media (max-width:640px){.card{padding:18px}}
.card:hover{transform:translateY(-3px);box-shadow:0 0 18px rgba(124,58,237,.4)}
@media (max-width:640px){.card:hover{transform:none}}
.card h3{margin:0 0 8px;font-size:clamp(1.1rem,2.5vw,1.2rem);line-height:1.3}
.list{margin:12px 0;padding-left:1.5rem;color:var(--muted);line-height:1.8}
.list li{margin:6px 0}
.list li strong{color:var(--text);font-weight:600}

/* Media blocks */
.card-media{width:clamp(240px,72%,520px);aspect-ratio:16/10;margin:0 auto 16px;border-radius:14px;outline:1px solid rgba(255,255,255,.08);
  box-shadow:0 8px 24px rgba(0,0,0,.35);background:rgba(255,255,255,.02);overflow:hidden}
.card-media img{width:100%;height:100%;object-fit:contain;object-position:center}
.card-media.round{width:clamp(200px,45%,360px);aspect-ratio:1/1;border-radius:50%;display:grid;place-items:center;overflow:hidden}
.card-media.round img{width:100%;height:100%;object-fit:cover;border-radius:inherit}

/* Two-column grid */
.two-columns{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(18px,3vw,24px)}
@media (max-width:640px){.two-columns{grid-template-columns:1fr;gap:16px}}

/* Projects */
.projects-grid{grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,24px)}
@media (max-width:1100px){.projects-grid{grid-template-columns:repeat(2,1fr);gap:clamp(18px,3vw,24px)}}
@media (max-width:700px){.projects-grid{grid-template-columns:1fr;gap:16px}}
.project{position:relative}
.project-link{cursor:pointer}
.project-link:hover{text-decoration:none}
.project-featured.card{border-color:rgba(251,191,36,.4);box-shadow:0 0 25px rgba(251,191,36,.4),0 0 40px rgba(251,191,36,.2),0 10px 30px rgba(0,0,0,.3);
  animation:cardGlow 3s ease-in-out infinite}
@keyframes cardGlow{0%,100%{box-shadow:0 0 25px rgba(251,191,36,.4),0 0 40px rgba(251,191,36,.2),0 10px 30px rgba(0,0,0,.3)}
  50%{box-shadow:0 0 35px rgba(251,191,36,.6),0 0 55px rgba(251,191,36,.3),0 10px 30px rgba(0,0,0,.3)}}
.project h3{margin:0 0 10px;font-size:1.25rem}
.project .project-thumb{width:160px;aspect-ratio:1/1;margin:10px auto 14px;border-radius:50%;overflow:hidden;display:grid;place-items:center;
  background:radial-gradient(60% 60% at 50% 40%, rgba(124,58,237,.35), rgba(217,70,239,.25)),#0b132a;
  border:1px solid rgba(124,92,255,.35);box-shadow:inset 0 0 30px rgba(124,58,237,.35),0 10px 22px rgba(0,0,0,.35)}
.project-featured .project-thumb.project-shine{position:relative;border:2px solid rgba(251,191,36,.5);
  box-shadow:0 0 20px rgba(251,191,36,.4),inset 0 0 30px rgba(251,191,36,.2),0 10px 22px rgba(0,0,0,.35);
  animation:shine 3s ease-in-out infinite}
@keyframes shine{0%,100%{box-shadow:0 0 20px rgba(251,191,36,.4),inset 0 0 30px rgba(251,191,36,.2),0 10px 22px rgba(0,0,0,.35)}
  50%{box-shadow:0 0 30px rgba(251,191,36,.6),inset 0 0 40px rgba(251,191,36,.3),0 10px 22px rgba(0,0,0,.35)}}
.star-badge{position:absolute;top:12px;right:12px;font-size:1.5rem;z-index:10;animation:starPulse 2s ease-in-out infinite;
  filter:drop-shadow(0 0 8px rgba(251,191,36,.8))}
@keyframes starPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.9}}
.project .project-desc{color:var(--muted);margin:8px 0 10px}
.project .project-tech{font-size:.9rem;color:#b7aefc;margin:4px 0 12px}
.stars-container{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden;border-radius:var(--radius)}
.star{position:absolute;color:#fbbf24;font-size:0.8rem;opacity:0;animation:starFloat 3s ease-out forwards}
@keyframes starFloat{0%{opacity:0;transform:translateY(0) scale(0)}10%{opacity:1}90%{opacity:1}100%{opacity:0;transform:translateY(-100px) scale(1.5)}}

/* Progress bar */
.progress{height:8px;background:rgba(255,255,255,.08);border-radius:999px;overflow:hidden}
.progress>span{display:block;height:100%;width:calc(var(--p,0) * 1%);background:linear-gradient(90deg,var(--success),#34d399);
  border-radius:inherit;box-shadow:0 0 10px rgba(34,197,94,.35)}
.progress-excited>span{background:linear-gradient(90deg,#fbbf24,#f59e0b);box-shadow:0 0 15px rgba(251,191,36,.5),0 0 25px rgba(251,191,36,.3);
  animation:progressGlow 2s ease-in-out infinite}
@keyframes progressGlow{0%,100%{box-shadow:0 0 15px rgba(251,191,36,.5),0 0 25px rgba(251,191,36,.3)}
  50%{box-shadow:0 0 20px rgba(251,191,36,.7),0 0 35px rgba(251,191,36,.5)}}
.progress-meta{display:flex;justify-content:space-between;font-size:.8rem;color:var(--muted);margin-top:6px}

/* Testimonial */
.section-subtitle{margin:6px 0 12px;font-size:1.15rem;color:#d4c2ff}
.clients{margin-top:26px}
.testimonial{display:grid;grid-template-columns:320px 1fr;align-items:center;gap:18px;padding:22px}
@media (max-width:820px){.testimonial{grid-template-columns:1fr;text-align:center}}
.client-side{display:flex;align-items:center;gap:14px}
@media (max-width:820px){.client-side{justify-content:center}}
.client-logo{width:72px;height:72px;border-radius:14px;display:grid;place-items:center;
  background:radial-gradient(60% 60% at 50% 40%, rgba(124,58,237,.35), rgba(217,70,239,.22)),#0b132a;
  border:1px solid rgba(124,92,255,.35);box-shadow:inset 0 0 22px rgba(124,58,237,.35),0 10px 22px rgba(0,0,0,.35);font-weight:800;color:#efe7ff}
.client-meta .client-name{font-weight:700}
.client-meta .client-role{color:var(--muted);font-size:.9rem}
.client-quote blockquote{margin:6px 0 0;color:var(--text);opacity:.95}
.stars{font-size:1.05rem;letter-spacing:.12rem;color:var(--warning);text-shadow:0 0 10px rgba(245,158,11,.35)}

/* Who */
#who{padding-top:clamp(40px,8vw,80px);position:relative}
@media (max-width:640px){#who{padding-top:36px}}
#who .container{position:relative}
.who-grid{display:grid;grid-template-columns:1fr;align-items:start;gap:clamp(20px,4vw,28px);margin-top:0;min-height:clamp(400px,60vh,600px)}
@media (min-width:880px){.who-grid{grid-template-columns:1.1fr 1fr;min-height:clamp(500px,70vh,800px)}}
@media (max-width:880px){.who-grid{grid-template-columns:1fr;gap:24px}}
.who-copy{display:flex;flex-direction:column;gap:16px}
.who-copy p{margin:10px;line-height:1.6}
.who-glance{margin-top:20px}
.who-image{align-self:start;margin:0;margin-top:0;overflow:hidden;position:relative}
@media (min-width:880px){.who-image{margin:0;position:absolute;right:clamp(16px,4vw,20px);top:0;width:45%;z-index:0;pointer-events:none;height:auto;transform:translateY(0)}}
.who-image img{max-height:none !important;height:clamp(500px,75vh,900px) !important;width:auto !important;max-width:none !important;display:block;object-fit:cover;object-position:top center;opacity:0.6;margin-top:0;vertical-align:top}
@media (max-width:880px){.who-image img{height:clamp(300px,50vh,500px) !important;max-width:100% !important;margin:0 auto;opacity:1}}
@media (min-width:1200px){.who-image img{height:clamp(600px,85vh,1000px) !important;object-position:top center}}
.who-grid{position:relative;z-index:1}
.who-copy{position:relative;z-index:2}

.people{margin-top:clamp(20px,4vw,40px);display:grid;gap:clamp(20px,4vw,28px);position:relative;z-index:2}
@media (max-width:880px){.people{margin-top:32px}}
.person{text-align:center}
.person h4{margin:10px 0 2px;font-size:1.05rem}
.person .role{margin:0 0 6px;color:#b7aefc;font-size:.9rem}
.person .bio{color:var(--muted);margin:6px 0 10px}
.person .tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.person.featured{max-width:560px;margin:0 auto;padding-top:22px}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,3vw,18px)}
@media (max-width:1100px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.team-grid{grid-template-columns:1fr;gap:16px}}
.person .avatar{width:140px;aspect-ratio:1/1;margin:0 auto 10px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(60% 60% at 50% 40%, rgba(124,58,237,.35), rgba(217,70,239,.25)),#0b132a;
  border:1px solid rgba(124,92,255,.35);box-shadow:inset 0 0 30px rgba(124,58,237,.35),0 10px 22px rgba(0,0,0,.35)}

/* Why + How */
.how-steps{display:grid;grid-template-columns:1fr 90px 1fr 90px 1fr 90px 1fr;align-items:stretch;gap:0;margin-top:8px}
.step{position:relative;padding:18px;padding-top:44px;text-align:left;margin:0 8px}
@media (max-width:640px){.step{padding:16px;padding-top:40px;margin:0 4px}}
.step h4{margin:0 0 6px;font-size:clamp(1rem,2.5vw,1.05rem);line-height:1.3}
.step p{margin:0;color:var(--muted);font-size:clamp(0.9rem,2vw,1rem);line-height:1.5}
.step-yellow{background:rgba(245,158,11,.10);border:1px solid rgba(245,158,11,.35)}
.step .step-num{position:absolute;top:22px;left:16px;width:clamp(28px,4vw,32px);height:clamp(28px,4vw,32px);border-radius:50%;display:grid;place-items:center;
  font-weight:800;font-size:clamp(0.9rem,2vw,1rem);background:var(--warning);color:#0b0914;box-shadow:0 0 0 4px rgba(245,158,11,.2),0 8px 18px rgba(0,0,0,.35)}
.connector{align-self:center;height:10px;border-radius:999px;background:linear-gradient(90deg,rgba(255,255,255,.12),rgba(245,158,11,.55));
  box-shadow:0 0 16px rgba(245,158,11,.25);position:relative;margin:0 -4px}
.connector::after{content:"";position:absolute;right:-5px;top:50%;transform:translateY(-50%);
  border-left:18px solid rgba(245,158,11,.85);border-top:10px solid transparent;border-bottom:10px solid transparent}
@media (max-width:980px){.how-steps{grid-template-columns:1fr;row-gap:clamp(12px,3vw,14px)}.connector{display:none}}

.why-grid{grid-template-columns:repeat(4,1fr);gap:clamp(16px,3vw,20px)}
@media (max-width:1080px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.why-grid{grid-template-columns:1fr;gap:16px}}
.reason{text-align:left}
.reason h3{margin:0 0 6px;font-size:clamp(1.05rem,2.5vw,1.15rem);line-height:1.3}
.reason p{margin:0;color:var(--muted);font-size:clamp(0.9rem,2vw,1rem);line-height:1.5}
.reason.accent-primary{background:rgba(124,58,237,.10);border:1px solid rgba(124,58,237,.35)}
.reason.accent-accent{background:rgba(217,70,239,.10);border:1px solid rgba(217,70,239,.32)}
.reason.accent-success{background:rgba(34,197,94,.10);border:1px solid rgba(34,197,94,.35)}
.reason.accent-warning{background:rgba(245,158,11,.10);border:1px solid rgba(245,158,11,.35)}

/* Investors */
:root{--cyan:#22d3ee;--indigo:#6366f1;--rose:#f43f5e}
#investors .section-kicker{color:#9ce7f6}
.investors-grid{grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,24px)}
@media (max-width:1000px){.investors-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.investors-grid{grid-template-columns:1fr;gap:16px}}
.investor-card h3{margin:0 0 8px;font-size:clamp(1.05rem,2.5vw,1.15rem);line-height:1.3}
.investor-card .muted{color:var(--muted);margin:0 0 8px}
.investor-card ul{margin:8px 0 0;padding-left:1.2rem;color:var(--muted)}
.investor-card li::marker{color:#9ce7f6}
.investor-card.accent-cyan{background:rgba(34,211,238,.10);border:1px solid rgba(34,211,238,.35)}
.investor-card.accent-indigo{background:rgba(99,102,241,.10);border:1px solid rgba(99,102,241,.35)}
.investor-card.accent-rose{background:rgba(244,63,94,.10);border:1px solid rgba(244,63,94,.35)}
.investor-metrics{grid-template-columns:repeat(3,1fr);gap:clamp(14px,3vw,18px);margin-top:clamp(18px,3vw,22px)}
@media (max-width:700px){.investor-metrics{grid-template-columns:1fr;gap:14px}}
.metric{text-align:center;padding:clamp(18px,3vw,22px) clamp(14px,3vw,18px)}
.metric .num{font-size:clamp(1.4rem,4vw,1.6rem);font-weight:800;line-height:1}
.metric .label{color:var(--muted);margin-top:6px;font-size:clamp(0.85rem,2vw,0.9rem)}
.metric:nth-child(1){background:rgba(34,211,238,.10);border:1px solid rgba(34,211,238,.28)}
.metric:nth-child(2){background:rgba(99,102,241,.10);border:1px solid rgba(99,102,241,.28)}
.metric:nth-child(3){background:rgba(244,63,94,.10);border:1px solid rgba(244,63,94,.28)}
.btn-investor{background:linear-gradient(135deg,var(--cyan),var(--indigo));color:#fff;border:none;
  box-shadow:0 6px 20px rgba(34,211,238,.35)}
.investors-cta{margin-top:22px}

/* CTA banner */
.cta-banner{background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(217,70,239,.15));
  border:1px solid rgba(124,92,255,.35);padding:clamp(20px,4vw,32px);border-radius:var(--radius);
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:clamp(14px,3vw,18px)}
@media (max-width:640px){.cta-banner{flex-direction:column;text-align:center;padding:20px}}
.cta-banner h2{font-size:clamp(1.3rem,3.5vw,1.8rem);line-height:1.3}
.cta-banner .cta-row{width:100%}
@media (max-width:640px){.cta-banner .cta-row{flex-direction:column}}

/* Contact form modal */
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:100;display:flex;align-items:center;justify-content:center;
  padding:clamp(12px,3vw,20px);opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}
.modal-overlay.reveal{opacity:1;visibility:visible}
.modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(11,9,20,.85);backdrop-filter:blur(8px);cursor:pointer}
.modal-container{position:relative;z-index:101;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;
  transform:scale(0.95) translateY(20px);transition:transform .3s ease}
@media (max-width:640px){.modal-container{max-height:95vh}}
.modal-overlay.reveal .modal-container{transform:scale(1) translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:clamp(16px,3vw,20px);padding-bottom:clamp(12px,3vw,16px);
  border-bottom:1px solid rgba(124,92,255,.25)}
.modal-header h2{font-size:clamp(1.3rem,3.5vw,1.5rem)}
.btn-close-modal{width:clamp(32px,4vw,36px);height:clamp(32px,4vw,36px);border-radius:50%;border:none;background:rgba(255,255,255,.08);
  color:var(--text);font-size:clamp(20px,3vw,24px);line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .2s;flex-shrink:0}
.btn-close-modal:hover{background:rgba(255,255,255,.15);transform:rotate(90deg)}
.btn-close-modal:active{transform:rotate(90deg) scale(0.95)}

.contact-form{max-width:100%;margin:0;display:grid;gap:clamp(10px,2vw,12px);padding:0}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(10px,2vw,12px)}
@media (max-width:700px){.contact-form .row{grid-template-columns:1fr;gap:12px}}
.contact-form label{display:grid;gap:8px;font-weight:600;font-size:clamp(0.9rem,2vw,0.95rem)}
.contact-form input,.contact-form textarea{width:100%;padding:clamp(10px,2vw,12px) clamp(12px,2.5vw,14px);border-radius:12px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);color:var(--text);font-size:clamp(0.9rem,2vw,1rem)}
.contact-form input:focus,.contact-form textarea:focus{outline:none;box-shadow:0 0 0 3px rgba(124,92,255,.25);border-color:rgba(124,92,255,.55)}
#contact-form{scroll-margin-top:0}

/* Footer */
footer{padding:clamp(32px,6vw,48px) 0;color:#a8a8cf;border-top:1px solid rgba(124,92,255,.2)}
@media (max-width:640px){footer{padding:28px 0}}
footer .container>div{flex-direction:column;text-align:center;gap:16px}
@media (min-width:640px){footer .container>div{flex-direction:row;text-align:left}}
.fine{font-size:clamp(0.85rem,2vw,0.9rem);color:#b3b3dd;line-height:1.5}


/* Reveal/hide for the contact form */
.is-hidden { display: none !important; }

#contact-form.reveal {
  animation: contact-reveal .26s ease;
}
@keyframes contact-reveal {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
