/* ═══════════════════════════════════════════════════
   CONTACT MODAL
   ═══════════════════════════════════════════════════ */
.contact-overlay{
  position:fixed;inset:0;z-index:9990;
  background:rgba(0,0,0,.0);
  backdrop-filter:blur(0);
  pointer-events:none;
  transition:background .5s ease,backdrop-filter .5s ease;
  display:flex;align-items:center;justify-content:center;
}
.contact-overlay.open{
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(12px);
  pointer-events:all;
}
.contact-glass{
  position:relative;
  width:min(480px,90vw);
  border-radius:var(--radius);
  border:1px solid var(--stroke);
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  box-shadow:0 32px 100px rgba(0,0,0,.6),0 0 60px rgba(124,92,255,.12);
  padding:36px 32px 32px;
  overflow:hidden;
  background-clip:padding-box;
  transform:perspective(800px) rotateX(12deg) translateY(60px) scale(.88);
  opacity:0;
  filter:blur(6px);
  transition:transform .65s cubic-bezier(.16,1.2,.3,1),
             opacity .45s ease,
             filter .5s ease;
  will-change:transform,opacity,filter;
}
.contact-overlay.open .contact-glass{
  transform:perspective(800px) rotateX(0deg) translateY(0) scale(1);
  opacity:1;
  filter:blur(0);
}
.contact-glass .tag{margin-bottom:18px}
.contact-glass h2{
  font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:6px;
}
.contact-glass .contact-sub{
  color:var(--muted);font-size:13px;line-height:1.6;margin-bottom:24px;
}
.contact-glass label{
  display:block;color:var(--muted);font-size:12px;
  font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  margin-bottom:6px;margin-top:16px;
}
.contact-glass label:first-of-type{margin-top:0}
.contact-glass input,
.contact-glass textarea{
  width:100%;padding:12px 14px;
  border-radius:12px;border:1px solid var(--stroke);
  background:rgba(255,255,255,.04);
  color:var(--text);font-size:14px;font-family:inherit;
  outline:none;transition:border-color .2s ease,box-shadow .2s ease;
  resize:vertical;
}
.contact-glass input:focus,
.contact-glass textarea:focus{
  border-color:var(--accentB);
  box-shadow:0 0 0 3px rgba(0,212,255,.15);
}
.contact-glass textarea{min-height:100px}
.contact-glass .contact-send{
  margin-top:22px;width:100%;padding:14px;
  border:none;border-radius:14px;cursor:pointer;
  font-size:15px;font-weight:700;font-family:inherit;
  color:#fff;
  background:linear-gradient(135deg,var(--accentA),var(--accentB));
  box-shadow:0 8px 30px rgba(124,92,255,.3);
  transition:transform .2s ease,box-shadow .2s ease;
}
.contact-glass .contact-send:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 40px rgba(124,92,255,.45);
}
.contact-glass .contact-send:active{transform:translateY(0)}
.contact-close{
  position:absolute;top:14px;right:14px;
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--stroke);background:rgba(255,255,255,.06);
  color:var(--muted);font-size:18px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .2s ease;
  padding:0;
  font-family:inherit;
  line-height:1;
}
.contact-close:hover{color:var(--text);background:rgba(255,255,255,.12)}
.contact-glass .contact-ok{
  display:none;text-align:center;padding:30px 0 10px;
}
.contact-glass .contact-ok svg{
  width:48px;height:48px;color:var(--accentB);margin-bottom:14px;
}
.contact-glass .contact-ok h3{font-size:18px;font-weight:700;margin-bottom:6px}
.contact-glass .contact-ok p{color:var(--muted);font-size:13px;line-height:1.6}
html[data-theme="light"] .contact-overlay.open{
  background:rgba(211,220,237,.42);
}
html[data-theme="light"] .contact-glass{
  border-color:rgba(119,144,193,.2);
  background:linear-gradient(180deg,rgba(255,255,255,.86),rgba(245,249,255,.76));
  box-shadow:0 32px 86px rgba(128,145,178,.18),0 0 44px rgba(74,108,255,.08);
}
html[data-theme="light"] .contact-glass input,
html[data-theme="light"] .contact-glass textarea{
  border-color:rgba(119,144,193,.2);
  background:rgba(255,255,255,.78);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88);
}
html[data-theme="light"] .contact-glass input:focus,
html[data-theme="light"] .contact-glass textarea:focus{
  box-shadow:0 0 0 3px rgba(8,188,231,.1);
}
html[data-theme="light"] .contact-close{
  background:rgba(255,255,255,.78);
}
html[data-theme="light"] .contact-close:hover{
  background:rgba(255,255,255,.94);
}
