:root{--portfolio-primary: #6366f1;--portfolio-primary-dark: #4f46e5;--portfolio-secondary: #8b5cf6;--portfolio-success: #10b981;--portfolio-warning: #f59e0b;--portfolio-danger: #ef4444;--portfolio-overlay: rgba(0, 0, 0, .75);--portfolio-radius: 16px;--portfolio-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--portfolio-shadow-lg: 0 25px 50px -12px rgba(0, 0, 0, .25);--portfolio-transition: all .3s cubic-bezier(.4, 0, .2, 1)}.portfolio-view-component{position:relative;width:100%}.portfolio-content-wrapper{width:100%;background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;overflow:hidden;margin:.5rem 0}.portfolio-main-content{width:100%}.portfolio-content-section-compact{padding:.75rem 1rem;border-bottom:1px solid #f3f4f6}.portfolio-content-section-compact:last-child,.portfolio-content-section-compact-last{padding:.75rem 1rem;border-bottom:none}.portfolio-section-header-compact{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.portfolio-section-title-compact{font-size:.875rem;font-weight:600;color:#1f2937}.portfolio-badge-compact{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:500;transition:var(--portfolio-transition)}.portfolio-badge-compact.portfolio-badge-success{background:#d1fae5;color:#065f46}.portfolio-badge-compact.portfolio-badge-warning{background:#fef3c7;color:#92400e}.portfolio-badge-compact.portfolio-badge-info{background:#dbeafe;color:#1e40af}.portfolio-badge-compact.portfolio-badge-purple{background:#ede9fe;color:#5b21b6}.portfolio-image-grid-compact{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}@media (min-width: 640px){.portfolio-image-grid-compact{grid-template-columns:repeat(3,1fr);gap:.75rem}}@media (min-width: 768px){.portfolio-image-grid-compact{grid-template-columns:repeat(4,1fr)}}.portfolio-image-item-compact{position:relative;aspect-ratio:1;border-radius:.5rem;overflow:hidden;cursor:pointer;background:#f3f4f6;transition:var(--portfolio-transition)}.portfolio-image-item-compact:hover{transform:scale(1.05);box-shadow:0 4px 6px -1px #0000001a}.portfolio-image-item-compact img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.portfolio-image-overlay-compact{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;color:#fff;font-size:1.25rem}.portfolio-image-item-compact:hover .portfolio-image-overlay-compact{opacity:1}.portfolio-file-list-compact{display:flex;flex-direction:column;gap:.5rem}.portfolio-file-item-compact{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:#f9fafb;border-radius:.5rem;transition:var(--portfolio-transition)}.portfolio-file-item-compact:hover{background:#f3f4f6}.portfolio-file-info-compact{flex:1;min-width:0}.portfolio-file-name-compact{font-size:.875rem;font-weight:500;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portfolio-file-actions-compact{display:flex;gap:.25rem;flex-shrink:0}.portfolio-btn-compact{display:inline-flex;align-items:center;justify-content:center;padding:.375rem .75rem;border-radius:.375rem;font-size:.875rem;font-weight:500;transition:var(--portfolio-transition);cursor:pointer;text-decoration:none}.portfolio-btn-compact.portfolio-btn-primary{background:var(--portfolio-primary);color:#fff}.portfolio-btn-compact.portfolio-btn-primary:hover{background:var(--portfolio-primary-dark)}.portfolio-btn-compact.portfolio-btn-outline{background:transparent;border:1px solid #d1d5db;color:#4b5563}.portfolio-btn-compact.portfolio-btn-outline:hover{background:#f9fafb;border-color:#9ca3af}[x-cloak]{display:none!important}.portfolio-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--portfolio-overlay);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);animation:fadeIn .3s ease}.portfolio-modal-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1.5rem;overflow-y:auto}.portfolio-modal-content{position:relative;width:100%;max-width:72rem;max-height:90vh;background:#fff;border-radius:var(--portfolio-radius);box-shadow:var(--portfolio-shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease}.portfolio-modal-header{position:relative;padding:1.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-shrink:0}.portfolio-modal-header:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 100%);opacity:0;transition:opacity .3s ease}.portfolio-modal-header:hover:before{opacity:1}.portfolio-header-icon{width:3rem;height:3rem;background:#fff3;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;color:#fff;flex-shrink:0}.portfolio-header-title{flex:1;min-width:0}.portfolio-header-title h3{font-size:1.5rem;font-weight:700;color:#fff;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portfolio-close-btn{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:#ffffff1a;border:none;border-radius:8px;color:#fff;cursor:pointer;transition:var(--portfolio-transition);flex-shrink:0}.portfolio-close-btn:hover{background:#ffffff40;transform:rotate(90deg)}.portfolio-modal-body{flex:1;overflow-y:auto;padding:2rem;background:#fafafa}.portfolio-content-section{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px #0000001a;transition:var(--portfolio-transition)}.portfolio-content-section:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-2px)}.portfolio-content-section:last-child{margin-bottom:0}.portfolio-section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.portfolio-section-icon{width:2.5rem;height:2.5rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;font-size:1rem}.portfolio-section-title{font-size:1.25rem;font-weight:700;color:#1f2937;margin:0}.portfolio-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:600;transition:var(--portfolio-transition)}.portfolio-badge:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000001a}.portfolio-badge-success{background:#d1fae5;color:#065f46}.portfolio-badge-warning{background:#fef3c7;color:#92400e}.portfolio-badge-info{background:#dbeafe;color:#1e40af}.portfolio-badge-purple{background:#f3e8ff;color:#6b21a8}.portfolio-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.portfolio-image-item{position:relative;aspect-ratio:16/9;border-radius:12px;overflow:hidden;cursor:pointer;background:#f3f4f6;transition:var(--portfolio-transition)}.portfolio-image-item:hover{transform:translateY(-4px);box-shadow:0 10px 15px #0003}.portfolio-image-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;transition:transform .3s ease}.portfolio-image-item:hover img{transform:scale(1.1)}.portfolio-image-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;transition:var(--portfolio-transition)}.portfolio-image-item:hover .portfolio-image-overlay{background:#00000080}.portfolio-file-list{display:flex;flex-direction:column;gap:.75rem}.portfolio-file-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9fafb;border-radius:10px;border-left:4px solid transparent;transition:var(--portfolio-transition)}.portfolio-file-item:hover{background:#fff;border-left-color:var(--portfolio-primary);transform:translate(4px);box-shadow:0 2px 4px #0000000d}.portfolio-file-icon{width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:8px;font-size:1.5rem;flex-shrink:0}.portfolio-file-info{flex:1;min-width:0}.portfolio-file-name{font-weight:600;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portfolio-file-type{font-size:.875rem;color:#6b7280}.portfolio-file-actions{display:flex;gap:.5rem;flex-shrink:0}.portfolio-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:var(--portfolio-transition);text-decoration:none}.portfolio-btn-primary{background:var(--portfolio-primary);color:#fff}.portfolio-btn-primary:hover{background:var(--portfolio-primary-dark);transform:translateY(-2px);box-shadow:0 4px 6px #6366f14d}.portfolio-btn-outline{background:#fff;color:var(--portfolio-primary);border:2px solid var(--portfolio-primary)}.portfolio-btn-outline:hover{background:var(--portfolio-primary);color:#fff}.portfolio-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.portfolio-spinner{width:3rem;height:3rem;border:4px solid #e5e7eb;border-top-color:var(--portfolio-primary);border-radius:50%;animation:spin 1s linear infinite}.portfolio-loading-text{font-size:1rem;color:#6b7280}.portfolio-empty{text-align:center;padding:4rem 2rem}.portfolio-empty-icon{font-size:5rem;color:#d1d5db;margin-bottom:1.5rem}.portfolio-empty-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin-bottom:.5rem}.portfolio-empty-text{font-size:1rem;color:#6b7280;margin-bottom:1.5rem}.portfolio-modal-footer{padding:1.25rem 2rem;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:.75rem;flex-shrink:0}.portfolio-modal-body::-webkit-scrollbar{width:10px}.portfolio-modal-body::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.portfolio-modal-body::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;border:2px solid #f1f1f1}.portfolio-modal-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5568d3,#6a3f8f)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.portfolio-modal-container-responsive{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:auto}@media (max-width: 640px){.portfolio-modal-container-responsive{padding:0;align-items:flex-start}}.portfolio-image-modal-content{position:relative;width:100%;max-width:90vw;max-height:90vh;background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}@media (max-width: 640px){.portfolio-image-modal-content{max-width:100vw;max-height:100vh;border-radius:0}}.portfolio-image-modal-body{position:relative;width:100%;max-height:calc(90vh - 4rem);background:#111827;display:flex;align-items:center;justify-content:center;overflow:auto;padding:1rem}@media (max-width: 640px){.portfolio-image-modal-body{max-height:calc(100vh - 3.5rem);padding:0}}.portfolio-modal-image{max-width:100%;max-height:100%;width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:.5rem;cursor:zoom-out}@media (max-width: 640px){.portfolio-modal-image{border-radius:0;width:100%;height:auto}}.portfolio-pdf-modal-content{position:relative;width:100%;max-width:95vw;max-height:95vh;background:#fff;border-radius:1rem;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}@media (max-width: 640px){.portfolio-pdf-modal-content{max-width:100vw;max-height:100vh;border-radius:0}}.portfolio-pdf-modal-body{position:relative;width:100%;height:calc(95vh - 4rem);background:#e5e7eb;overflow:hidden}@media (max-width: 640px){.portfolio-pdf-modal-body{height:calc(100vh - 3.5rem)}}.portfolio-pdf-iframe{width:100%;height:100%;border:0}.portfolio-pdf-fallback{display:none;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:2rem;text-align:center}.portfolio-modal-header-compact{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background:#fff;border-bottom:1px solid #e5e7eb}@media (max-width: 640px){.portfolio-modal-header-compact{padding:.625rem .875rem}}.portfolio-close-btn-compact{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;background:#f3f4f6;border:none;border-radius:.5rem;color:#6b7280;cursor:pointer;transition:var(--portfolio-transition);flex-shrink:0}.portfolio-close-btn-compact:hover{background:#e5e7eb;color:#374151}@media (max-width: 640px){.portfolio-close-btn-compact{width:1.75rem;height:1.75rem}}@media (max-width: 768px){.portfolio-modal-container{padding:.5rem}.portfolio-modal-content{max-height:95vh;border-radius:12px}.portfolio-modal-header{padding:1.25rem 1rem}.portfolio-header-title h3{font-size:1.125rem}.portfolio-modal-body,.portfolio-content-section{padding:1rem}.portfolio-image-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.portfolio-file-item{flex-direction:column;align-items:flex-start;gap:.75rem}.portfolio-file-actions{width:100%;flex-direction:column}.portfolio-btn{width:100%}.portfolio-content-section-compact{padding:.625rem .75rem}.portfolio-file-item-compact{padding:.375rem;gap:.5rem}.portfolio-file-name-compact{font-size:.8125rem}}@media (max-width: 480px){.portfolio-image-grid{grid-template-columns:1fr}.portfolio-content-wrapper{border-radius:.5rem;margin:.25rem 0}.portfolio-content-section-compact{padding:.5rem .625rem}.portfolio-badge-compact{font-size:.6875rem;padding:.1875rem .375rem}.portfolio-section-title-compact{font-size:.8125rem}.portfolio-image-grid-compact{grid-template-columns:repeat(2,1fr);gap:.375rem}.portfolio-btn-compact{padding:.25rem .5rem;font-size:.8125rem}}@media print{.portfolio-modal-backdrop,.portfolio-modal-container,.portfolio-modal-container-responsive{display:none!important}}
