.modal-overlay[data-v-7fccf005]{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;background:#020617e6;backdrop-filter:blur(4px)}.modal-content[data-v-7fccf005]{position:relative;width:100%;max-width:56rem;max-height:90vh;overflow:hidden;border-radius:1.5rem;background:#0f172a;border:1px solid rgba(51,65,85,.5);box-shadow:0 25px 50px -12px #00000080}.close-btn[data-v-7fccf005]{position:absolute;top:1rem;right:1rem;z-index:10;width:2.5rem;height:2.5rem;border-radius:9999px;background:#1e293bcc;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;color:#94a3b8;border:none;cursor:pointer;transition:all .2s}.close-btn[data-v-7fccf005]:hover{color:#fff;background:#334155}.modal-scroll[data-v-7fccf005]{overflow-y:auto;max-height:90vh}.modal-image[data-v-7fccf005]{position:relative;aspect-ratio:16 / 9;width:100%;overflow:hidden}.modal-image img[data-v-7fccf005]{width:100%;height:100%;object-fit:cover}.image-overlay[data-v-7fccf005]{position:absolute;inset:0;background:linear-gradient(to top,rgb(15,23,42),transparent,transparent)}.category-badge[data-v-7fccf005]{position:absolute;top:1rem;left:1rem;padding:.375rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:500;background:#3b82f6cc;backdrop-filter:blur(4px);color:#fff}.year-badge[data-v-7fccf005]{position:absolute;bottom:1rem;right:1rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background:#1e293bcc;backdrop-filter:blur(4px);color:#cbd5e1}.modal-body[data-v-7fccf005]{padding:1.5rem 2rem 2rem}.modal-title[data-v-7fccf005]{font-size:1.5rem;font-weight:700;color:#fff;margin-bottom:1rem}@media(min-width:640px){.modal-title[data-v-7fccf005]{font-size:1.875rem}}.modal-description[data-v-7fccf005]{margin-bottom:2rem}.modal-description p[data-v-7fccf005]{color:#94a3b8;line-height:1.625;white-space:pre-line}.modal-grid[data-v-7fccf005]{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:2rem}@media(min-width:1024px){.modal-grid[data-v-7fccf005]{grid-template-columns:1fr 1fr}}.modal-card[data-v-7fccf005]{background:#1e293b80;backdrop-filter:blur(8px);border-radius:1rem;padding:1.5rem;border:1px solid rgba(51,65,85,.5)}.card-title[data-v-7fccf005]{font-size:1.125rem;font-weight:600;color:#fff;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.card-icon[data-v-7fccf005]{width:2rem;height:2rem;border-radius:.5rem;display:flex;align-items:center;justify-content:center}.features-list[data-v-7fccf005]{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.features-list li[data-v-7fccf005]{display:flex;align-items:flex-start;gap:.75rem;color:#94a3b8}.tech-tags[data-v-7fccf005]{display:flex;flex-wrap:wrap;gap:.5rem}.tech-tag[data-v-7fccf005]{padding:.375rem .75rem;border-radius:.5rem;font-size:.875rem;background:#1e293b;color:#cbd5e1;border:1px solid rgba(51,65,85,.5);transition:border-color .2s}.tech-tag[data-v-7fccf005]:hover{border-color:#3b82f680}.modal-cta[data-v-7fccf005]{display:flex;flex-direction:column;gap:1rem;padding-top:1rem;border-top:1px solid rgb(30,41,59)}@media(min-width:640px){.modal-cta[data-v-7fccf005]{flex-direction:row}}.cta-primary[data-v-7fccf005]{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 1.5rem;border-radius:.75rem;background:#2563eb;color:#fff;font-weight:600;text-decoration:none;transition:all .3s;box-shadow:0 10px 15px -3px #3b82f640}.cta-primary[data-v-7fccf005]:hover{background:#3b82f6;box-shadow:0 10px 15px -3px #3b82f666}.cta-secondary[data-v-7fccf005]{padding:1rem 1.5rem;border-radius:.75rem;background:#1e293b80;color:#cbd5e1;font-weight:500;border:1px solid rgba(51,65,85,.5);cursor:pointer;transition:all .2s}.cta-secondary[data-v-7fccf005]:hover{color:#fff;background:#33415580}.modal-enter-active[data-v-7fccf005],.modal-leave-active[data-v-7fccf005]{transition:all .3s ease}.modal-enter-from[data-v-7fccf005],.modal-leave-to[data-v-7fccf005]{opacity:0}.modal-enter-from .modal-content[data-v-7fccf005],.modal-leave-to .modal-content[data-v-7fccf005]{transform:scale(.95) translateY(20px)}
