*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#fff;--secondary-color:#f8fafc;--accent-color:#78b9b5;--accent-hover:#0f828c;--text-color:#1f2937;--text-muted:#9ca3af;--bg-primary:#fff;--bg-secondary:#f9fafb;--bg-tertiary:#f3f4f6;--border-color:#e5e7eb;--border-light:#f3f4f6;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--transition:all 0.2s ease-in-out;--radius-sm:0.25rem;--radius:0.5rem;--radius-md:0.75rem;--radius-lg:1rem;--radius-xl:1.5rem}.dark,[data-theme=dark]{--primary-color:#1f2937;--secondary-color:#111827;--accent-color:#78b9b5;--accent-hover:#0f828c;--text-color:#f9fafb;--text-secondary:#d1d5db;--text-muted:#9ca3af;--bg-primary:#1f2937;--bg-secondary:#111827;--bg-tertiary:#0f172a;--border-color:#374151;--border-light:#4b5563;--shadow:0 1px 3px 0 #0000004d,0 1px 2px 0 #0003;--shadow-md:0 4px 6px -1px #0000004d,0 2px 4px -1px #0003;--shadow-lg:0 10px 15px -3px #0000004d,0 4px 6px -2px #0003;--shadow-xl:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003}body{background-color:#fff;background-color:var(--bg-primary);color:#1f2937;color:var(--text-color);transition:all .2s ease-in-out;transition:var(--transition)}.container{padding:0 1rem}.btn{border-radius:var(--radius);transition:all .2s ease-in-out;transition:var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:#78b9b5}.btn-primary:hover:not(:disabled){background-color:var(--accent-hover)}.btn-secondary{background-color:#f8fafc;border:1px solid #e5e7eb;color:#1f2937}.btn-secondary:hover:not(:disabled){background-color:#f3f4f6;background-color:var(--bg-tertiary)}.btn-outline{background-color:initial;border:1px solid #78b9b5;color:#78b9b5}.btn-outline:hover:not(:disabled){background-color:#78b9b5;background-color:var(--accent-color);color:#fff}.form-group{margin-bottom:1rem}.form-input,.form-label{color:#1f2937}.form-input{background-color:#fff;border:1px solid #e5e7eb;transition:all .2s ease-in-out}.form-input:focus{border-color:#78b9b5}.form-input::placeholder{color:#9ca3af}.card{background-color:#fff;background-color:var(--primary-color);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:1rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow);padding:1.5rem;transition:all .2s ease-in-out;transition:var(--transition)}.card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}@media (max-width:768px){.container{padding:0 .75rem}.btn{font-size:.875rem;padding:.625rem 1.25rem}.card{padding:1rem}}@media (max-width:480px){.container{padding:0 .5rem}.btn{font-size:.8rem;padding:.5rem 1rem}.card{padding:.75rem}}.fade-in{animation:fadeIn .3s ease-out}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f9fafb;background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--text-muted)}::selection{background-color:#78b9b5;background-color:var(--accent-color);color:#fff}::-moz-selection{background-color:#78b9b5;background-color:var(--accent-color);color:#fff}.navbar{background-color:var(--primary-color);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow);left:0;position:fixed;right:0;top:0;z-index:1000}.navbar-container{height:70px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 1rem}.navbar-container,.navbar-logo{align-items:center;display:flex}.navbar-logo{color:var(--text-color);font-size:1.5rem;font-weight:700;text-decoration:none;transition:color .2s ease}.navbar-logo:hover{color:var(--accent-color)}.logo-icon{color:#fff;height:32px;margin-right:.5rem;width:32px}.logo-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-color),#0f828c);-webkit-background-clip:text;background-clip:text}.navbar-menu{gap:1rem}.navbar-link,.navbar-menu{align-items:center;display:flex}.navbar-link{border-radius:.375rem;color:var(--text-color);font-weight:500;gap:.5rem;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.navbar-link:hover{background-color:var(--secondary-color);color:var(--accent-color)}.navbar-link-primary{background-color:var(--accent-color);color:#fff}.navbar-link-primary:hover{background-color:#0f828c;color:#fff}.navbar-dropdown{position:relative}.navbar-user{align-items:center;background:none;border:none;border-radius:.375rem;color:var(--text-color);cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.navbar-user:hover{background-color:var(--secondary-color)}.navbar-user .user-avatar{align-items:center;background:linear-gradient(135deg,var(--accent-color),#0f828c);border-radius:50%;display:flex;flex-shrink:0;height:32px;justify-content:center;overflow:hidden;width:32px}.navbar-user .avatar-image{border-radius:50%;display:block;height:100%;object-fit:cover;width:100%}.navbar-user .icon{color:#fff;height:18px;width:18px}.dropdown-content{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:var(--shadow-lg);min-width:200px;opacity:0;position:absolute;right:0;top:100%;transform:translateY(-10px);transition:all .2s ease;visibility:hidden;z-index:1001}.navbar-dropdown:hover .dropdown-content{opacity:1;transform:translateY(0);visibility:visible}.dropdown-link{align-items:center;background:none;border:none;color:var(--text-color);cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.75rem 1rem;text-decoration:none;transition:background-color .2s ease;width:100%}.dropdown-link:hover{background-color:var(--secondary-color)}.dropdown-link:first-child{border-radius:.5rem .5rem 0 0}.dropdown-link:last-child{border-radius:0 0 .5rem .5rem}.theme-toggle{align-items:center;background:none;border:none;border-radius:.375rem;color:var(--text-color);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s ease;width:40px}.theme-toggle:hover{background-color:var(--secondary-color);color:var(--accent-color)}.mobile-menu-toggle{align-items:center;background:none;border:none;border-radius:.375rem;color:var(--text-color);cursor:pointer;display:none;height:40px;justify-content:center;transition:all .2s ease;width:40px}.mobile-menu-toggle:hover{background-color:var(--secondary-color)}.mobile-menu{background-color:var(--primary-color);border-bottom:1px solid var(--border-color);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:.5rem;left:0;padding:1rem;position:absolute;right:0;top:100%}.mobile-user-info{align-items:center;background-color:var(--secondary-color);border-radius:.375rem;display:flex;font-weight:500;gap:.5rem;margin-bottom:.5rem;padding:.75rem}.mobile-user-info .user-avatar{align-items:center;background:linear-gradient(135deg,var(--accent-color),#b91c1c);border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;width:40px}.mobile-user-info .avatar-image{border-radius:50%;display:block;height:100%;object-fit:cover;width:100%}.mobile-user-info .icon{color:#fff;height:20px;width:20px}.mobile-link{align-items:center;background:none;border:none;border-radius:.375rem;color:var(--text-color);cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:all .2s ease;width:100%}.mobile-link:hover{background-color:var(--secondary-color)}.mobile-link-primary{background-color:var(--accent-color);color:#fff}.mobile-link-primary:hover{background-color:#b91c1c;color:#fff}.mobile-link-button{background:none;border:none;cursor:pointer}@media (max-width:768px){.navbar-menu{display:none}.mobile-menu-toggle{display:flex}.navbar-container{height:60px}.logo-text{font-size:1.25rem}.logo-icon{height:28px;width:28px}}@media (max-width:480px){.navbar-container{padding:0 .5rem}.logo-text{font-size:1.125rem}}.app-footer{border-top:1px solid var(--border-color);color:var(--text-secondary);font-size:.875rem;margin-top:auto;padding:1rem 1.5rem;text-align:center}.app-footer-text{margin:0}.loading-container{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center;min-height:200px}.spinner{animation:spin 1s linear infinite;border-top:3px solid var(--border-color);border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--accent-color)}.spinner-small{border-width:2px;height:20px;width:20px}.spinner-medium{border-width:3px;height:40px;width:40px}.spinner-large{border-width:4px;height:60px;width:60px}.loading-text{color:var(--text-secondary);font-size:.875rem;margin:0}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.auth-page{align-items:center;background:linear-gradient(135deg,var(--secondary-color) 0,var(--primary-color) 100%);display:flex;justify-content:center;min-height:100vh;padding:2rem 1rem}.auth-layout{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;max-width:1200px;width:100%}.auth-landing{align-items:center;display:flex;justify-content:center;padding:2rem}.landing-content{animation:fadeInLeft .6s ease-out;max-width:500px}.landing-logo{align-items:center;display:flex;gap:1rem;margin-bottom:2rem}.landing-logo-icon{align-items:center;background:linear-gradient(135deg,var(--accent-color),#0f828c);border-radius:50%;box-shadow:var(--shadow-lg);display:flex;height:64px;justify-content:center;width:64px}.landing-logo-icon .icon{color:#fff;height:32px;width:32px}.landing-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-color),#0f828c);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;margin:0}.landing-headline{color:var(--text-color);font-size:2rem;font-weight:700;line-height:1.3;margin-bottom:1.5rem}.landing-description{color:var(--text-secondary);font-size:1.125rem;line-height:1.7;margin-bottom:2.5rem}.landing-features{display:flex;flex-direction:column;gap:1.25rem}.feature-item{align-items:center;color:var(--text-color);display:flex;font-size:1rem;font-weight:500;gap:.75rem}.feature-icon{color:var(--accent-color);flex-shrink:0;height:24px;width:24px}.auth-section{align-items:center;display:flex;justify-content:center;padding:2rem}.auth-container{max-width:400px;width:100%}.auth-card{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem;transition:var(--transition)}.auth-card,.auth-card:hover{box-shadow:var(--shadow-xl)}.auth-header{margin-bottom:2rem}.back-button{margin-bottom:1.5rem}.auth-logo{text-align:center}.logo-icon{align-items:center;background:linear-gradient(135deg,var(--accent-color),#0f828c);border-radius:50%;box-shadow:var(--shadow);display:flex;height:64px;justify-content:center;margin:0 auto 1rem;width:64px}.logo-icon .icon{color:#fff;height:32px;width:32px}.auth-title{color:var(--text-color);font-size:2rem;font-weight:700;margin-bottom:.5rem}.auth-subtitle{color:var(--text-secondary);font-size:1rem;line-height:1.5}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.form-input{border-radius:var(--radius);transition:var(--transition)}.form-input::placeholder{color:var(--text-muted)}.form-error{align-items:center;display:flex;gap:.25rem}.form-error .icon{height:14px;width:14px}.password-toggle{border-radius:var(--radius-sm)}.auth-submit{font-size:1rem;font-weight:600;margin-top:.5rem;padding:.875rem 1.5rem;width:100%}.auth-footer{margin-top:2rem;text-align:center}.auth-footer-text{color:var(--text-secondary);font-size:.875rem}.auth-link{color:var(--accent-color);font-weight:600;text-decoration:none;transition:color .2s ease}.auth-link:hover{color:var(--accent-hover);text-decoration:underline}.auth-link-wrap{font-size:.875rem;margin:-.25rem 0 .75rem}.auth-link-button{background:none;border:none;color:var(--accent-color);cursor:pointer;font-size:inherit;font-weight:600;padding:0;text-decoration:none;transition:color .2s ease}.auth-link-button:hover{color:var(--accent-hover);text-decoration:underline}@media (max-width:968px){.auth-layout{gap:3rem;grid-template-columns:1fr;max-width:600px}.auth-landing{order:1;padding:1.5rem}.auth-section{order:2;padding:1rem}.landing-content{max-width:100%;text-align:center}.landing-logo{justify-content:center}.landing-headline{font-size:1.75rem}.landing-description{font-size:1rem}.landing-features{align-items:center}}@media (max-width:480px){.auth-page{padding:1rem .5rem}.auth-layout{gap:2rem}.auth-card{padding:1.5rem}.auth-title{font-size:1.75rem}.logo-icon{height:56px;width:56px}.logo-icon .icon{height:28px;width:28px}.landing-logo-icon{height:56px;width:56px}.landing-logo-icon .icon{height:28px;width:28px}.landing-title{font-size:2rem}.landing-headline{font-size:1.5rem;margin-bottom:1rem}.landing-description{font-size:.9375rem;margin-bottom:2rem}.feature-item{font-size:.9375rem}.feature-icon{height:20px;width:20px}}.auth-card{animation:fadeInRight .6s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}@keyframes fadeInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.auth-submit:disabled{cursor:not-allowed;opacity:.7}.form-input:focus,.password-toggle:focus{outline:2px solid var(--accent-color);outline-offset:2px}.form-input:valid:not(:placeholder-shown){border-color:#10b981}.form-input:invalid:not(:placeholder-shown){border-color:#ef4444}.add-to-calendar-wrapper{display:inline-flex;position:relative}.add-to-calendar-btn{align-items:center;background:var(--secondary-color);border:none;border-radius:6px;border-radius:var(--radius,6px);color:var(--text-secondary);cursor:pointer;display:inline-flex;height:32px;justify-content:center;padding:0;transition:background .2s,color .2s;width:32px}.add-to-calendar-btn:hover{background:var(--accent-color);color:#fff}.add-to-calendar-btn .icon{height:16px;width:16px}.add-to-calendar-header{margin-right:4px}.add-to-calendar-btn-header{background-color:var(--secondary-color);border:1px solid var(--border-color);color:var(--text-color);height:auto;padding:.75rem 1.5rem;width:auto}.add-to-calendar-btn-header:hover{background-color:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-color)}.add-to-calendar-dropdown{background:var(--primary-color);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-lg);left:0;margin-top:4px;min-width:180px;padding:8px 0;position:absolute;top:100%;z-index:100}.add-to-calendar-option{background:none;border:none;color:var(--text-color);cursor:pointer;display:block;font-size:14px;padding:8px 16px;text-align:left;transition:background .15s;width:100%}.add-to-calendar-option:hover{background:var(--bg-tertiary)}.add-to-calendar-hint{border-top:1px solid var(--border-color);color:var(--text-muted);font-size:11px;line-height:1.3;margin:8px 12px 0;padding-top:8px}.dashboard{background:linear-gradient(135deg,var(--secondary-color) 0,var(--primary-color) 100%);min-height:calc(100vh - 80px);padding:2rem 0}.container{margin:0 auto;max-width:1200px;padding:0 1.5rem}.dashboard-header{align-items:flex-start;display:flex;gap:2rem;justify-content:space-between;margin-bottom:2rem}.welcome-section{flex:1 1}.dashboard-title{color:var(--text-color);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.dashboard-subtitle{color:var(--text-secondary);font-size:1.1rem}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.insights-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:3rem}.insight-card{align-items:center;background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;gap:1rem;padding:1.5rem;transition:var(--transition)}.insight-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.insight-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:60px;justify-content:center;width:60px}.insight-icon.total{background:linear-gradient(135deg,#3b82f6,#0f828c);color:#fff}.insight-icon.expiring{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.insight-icon.expired{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.insight-icon.public{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.insight-icon .icon{height:28px;width:28px}.insight-content{flex:1 1}.insight-value{color:var(--text-color);font-size:2rem;font-weight:700;margin-bottom:.25rem}.insight-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.form-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.form-card{background-color:var(--primary-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.form-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 1.5rem 0}.form-title{color:var(--text-color);font-size:1.5rem;font-weight:600}.close-button{background:none;border:none;border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;font-size:1.5rem;padding:.25rem;transition:var(--transition)}.close-button:hover{background-color:var(--secondary-color);color:var(--text-color)}.certification-form{padding:0 1.5rem 1.5rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.checkbox-group,.checkbox-label{align-items:center;display:flex}.checkbox-label{color:var(--text-color);cursor:pointer;font-size:.875rem;gap:.5rem}.checkbox-label input[type=checkbox]{accent-color:var(--accent-color);height:16px;width:16px}.checkbox-text{font-weight:500}.form-actions{gap:1rem;margin-top:2rem;padding-top:1.5rem}.section-title{font-size:1.75rem;margin-bottom:1.5rem}.section-header-with-sort{flex-direction:column;margin-bottom:1.5rem}.section-header-row{align-items:center;display:flex;gap:1rem;justify-content:space-between;width:100%}.section-header-with-sort .section-title{flex-shrink:0}.section-header-buttons{align-items:stretch;display:flex;flex-shrink:0;gap:1rem}.section-sort-row{display:flex;justify-content:flex-end;width:100%}.btn-ai-tip{align-items:center;display:inline-flex;gap:.5rem}.empty-state{border-radius:var(--radius-lg)}.empty-icon{color:var(--text-muted)}.empty-state p{margin-bottom:2rem}.certification-card{align-items:flex-start;background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;flex-direction:row;gap:1rem;padding:1.5rem;transition:var(--transition)}.certification-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.certification-card-main{flex:1 1;min-width:0}.certification-icon{color:#fff}.certification-actions{align-items:center;border-left:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;gap:.5rem;padding-left:1rem}.action-button{align-items:center;border:none;border-radius:var(--radius);cursor:pointer;display:flex;height:32px;justify-content:center;transition:var(--transition);width:32px}.action-button.edit{background-color:var(--secondary-color);color:var(--text-color)}.action-button.edit:hover{background-color:#3b82f6;color:#fff}.action-button.delete{background-color:var(--secondary-color);color:var(--text-color)}.action-button.delete:hover{background-color:#ef4444;color:#fff}.action-button .icon{height:16px;width:16px}.certification-badges{display:flex;gap:.5rem;margin-top:.5rem}.badge{align-items:center;border-radius:var(--radius);display:flex;font-size:.75rem;font-weight:600;gap:.25rem;padding:.25rem .5rem}.badge.public{background-color:#10b9811a;color:#059669}.badge.notification{background-color:#3b82f61a;color:#526ed6}.badge .icon{height:12px;width:12px}.portfolio-link{align-items:flex-start;background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;gap:1.5rem;justify-content:space-between;padding:1.5rem}.portfolio-info h3{color:var(--text-color);font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.portfolio-info p{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.portfolio-url{background-color:var(--secondary-color);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);flex-wrap:wrap;font-family:monospace;font-size:.8rem;padding:.5rem .75rem;word-break:break-all}.portfolio-actions{align-items:center;display:flex;flex-shrink:0;gap:1rem}@media (max-width:768px){.dashboard-header{flex-direction:column;gap:1rem}.header-actions{justify-content:flex-end;width:100%}.certifications-grid,.form-row,.insights-grid{grid-template-columns:1fr}.form-actions,.portfolio-link{flex-direction:column}.portfolio-link{gap:1rem;text-align:center}.portfolio-actions{justify-content:center}.header-actions{align-items:flex-end;flex-direction:column;gap:.75rem}.section-header-row{align-items:stretch;flex-direction:column}.section-header-buttons{align-self:flex-end}.certification-header{align-items:flex-start;flex-direction:column}.certification-card{flex-direction:column}.certification-actions{border-left:none;border-top:1px solid var(--border-color);flex-direction:row;flex-wrap:wrap;justify-content:flex-end;padding-left:0;padding-top:1rem;width:100%}}@media (max-width:480px){.container{padding:0 1rem}.dashboard-title{font-size:2rem}.insight-card{padding:1rem}.insight-icon{height:48px;width:48px}.insight-icon .icon{height:24px;width:24px}.insight-value{font-size:1.5rem}.certification-card{padding:1rem}.section-header-row{align-items:stretch;flex-direction:column}.section-header-buttons{flex-direction:column;gap:.75rem;width:100%}.section-header-buttons>*{align-items:center;display:flex;flex:1 1;justify-content:center;min-width:0}.section-header-buttons .add-to-calendar-wrapper{display:flex}.section-header-buttons .add-to-calendar-wrapper .add-to-calendar-btn{flex:1 1;width:100%}.section-sort-row{justify-content:flex-start}.sort-controls{flex-wrap:wrap}.form-card{margin:.5rem}}.modal.modal-ai-insight{background-color:var(--primary-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.modal-ai-insight .modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:0;padding:1.5rem 1.5rem 0}.modal-ai-insight .modal-title{align-items:center;color:var(--text-color);display:flex;font-size:1.25rem;font-weight:600;gap:.5rem}.modal-ai-insight .modal-body{padding:1.5rem}.modal-export-actions{border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding-top:1rem}.modal-ai-insight .ai-insight-header{margin-bottom:1rem}.modal-ai-insight .ai-insight-header h3{color:var(--text-color);font-size:1.125rem;font-weight:600;margin:0}.modal-ai-insight .ai-insight-loading{color:var(--text-secondary);font-size:.9375rem;padding:.5rem 0}.modal-ai-insight .ai-error{background-color:#ef444414;border:1px solid #ef444440;border-radius:.5rem;color:var(--text-color);font-size:.875rem;padding:.75rem}.modal-ai-insight .ai-error-hint{color:var(--text-secondary);font-size:.8125rem;margin-top:.5rem}.modal-ai-insight .ai-insight-content{color:var(--text-color);font-size:.9375rem;line-height:1.6}.modal-ai-insight .ai-insight-content h2{color:var(--text-color);font-size:1.0625rem;font-weight:600;margin:1rem 0 .5rem}.modal-ai-insight .ai-insight-content h2:first-child{margin-top:0}.modal-ai-insight .ai-insight-content p{margin:0 0 .5rem}.modal-ai-insight .ai-insight-content strong{font-weight:600}.modal-ai-insight .ai-insight-content ol,.modal-ai-insight .ai-insight-content ul{margin:.25rem 0 .5rem;padding-left:1.25rem}.profile{background:linear-gradient(135deg,var(--secondary-color) 0,var(--primary-color) 100%);min-height:calc(100vh - 80px);padding:2rem 0}.profile-tabs{background-color:var(--primary-color);border-radius:.75rem;box-shadow:var(--shadow);display:flex;gap:.5rem;margin-bottom:2rem;padding:.5rem}.tab-button{align-items:center;background:#0000;border:none;border-radius:.5rem;color:var(--text-secondary);cursor:pointer;display:flex;flex:1 1;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .2s ease}.tab-button:hover{background-color:var(--secondary-color);color:var(--text-color)}.tab-button.active{background-color:var(--accent-color);box-shadow:var(--shadow);color:#fff}.tab-icon{height:18px;width:18px}.profile-header{margin-bottom:2rem}.back-button{margin-bottom:1rem}.profile-title{color:var(--text-color);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.profile-subtitle{color:var(--text-secondary);font-size:1.125rem}.profile-content{margin:0 auto;max-width:600px}.profile-card{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:1rem;box-shadow:var(--shadow-lg);padding:2rem}.profile-card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:1.5rem;margin-bottom:2rem;padding-bottom:2rem}.profile-avatar{align-items:center;background:linear-gradient(135deg,var(--accent-color),#361cb9);border-radius:50%;box-shadow:var(--shadow);display:flex;flex-shrink:0;height:80px;justify-content:center;width:80px}.avatar-icon{height:40px;width:40px}.profile-info{flex:1 1}.profile-name{color:var(--text-color);font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.profile-email{color:var(--text-secondary);font-size:1rem;margin-bottom:.75rem}.profile-status{align-items:center;color:#10b981;display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.status-icon{height:16px;width:16px}.profile-form{gap:2rem}.form-section,.profile-form{display:flex;flex-direction:column}.form-section{gap:1.5rem}.section-title{font-size:1.25rem;margin-bottom:.5rem}.section-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{align-items:center;color:var(--text-color);display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.form-icon{color:var(--text-secondary);height:16px;width:16px}.form-input{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-color);font-size:1rem;padding:.75rem 1rem;transition:all .2s ease;width:100%}.form-input:focus{border-color:var(--accent-color);box-shadow:0 0 0 3px #dc26261a;outline:none}.form-input-error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.form-error{color:#ef4444;font-size:.75rem;font-weight:500}.form-help{color:var(--text-secondary);font-size:.75rem;line-height:1.4;margin-top:.25rem}.profile-picture-actions{align-items:center;display:flex;gap:.75rem;margin-bottom:.5rem}.profile-picture-actions .form-help-inline{color:var(--text-secondary);font-size:.875rem}.url-input-container{align-items:center;background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:.5rem;display:flex;overflow:hidden}.url-prefix{background-color:var(--secondary-color);border-right:1px solid var(--border-color);color:var(--text-secondary);font-size:.875rem;font-weight:500;padding:.75rem 1rem;white-space:nowrap}.url-input{border:none;border-radius:0;flex:1 1;padding-left:.75rem}.url-input:focus{box-shadow:none;outline:none}.url-input-container:focus-within{border-color:var(--accent-color);box-shadow:0 0 0 3px #dc26261a}.password-input-container{position:relative}.password-toggle{background:none;border:none;border-radius:.25rem;color:var(--text-secondary);cursor:pointer;padding:.25rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:color .2s ease}.password-toggle:hover{color:var(--text-color)}.password-toggle .icon{height:18px;width:18px}.form-actions{border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;padding-top:1rem}.btn{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.btn-primary{background-color:var(--accent-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:#0f828c}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.icon{height:20px;width:20px}@media (max-width:768px){.profile{padding:1rem 0}.profile-title{font-size:2rem}.profile-card{padding:1.5rem}.profile-card-header{flex-direction:column;gap:1rem;text-align:center}.profile-avatar{height:60px;width:60px}.avatar-icon{height:30px;width:30px}.profile-name{font-size:1.25rem}.form-actions{justify-content:stretch}.btn{width:100%}}@media (max-width:480px){.profile-card{padding:1rem}.profile-title{font-size:1.75rem}.profile-avatar{height:50px;width:50px}.avatar-icon{height:25px;width:25px}}.card-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem}.header-icon{background-color:#dc26261a;border-radius:.75rem;color:var(--accent-color);height:48px;padding:.75rem;width:48px}.danger-icon{background-color:#ef44441a;color:#ef4444}.card-title{color:var(--text-color);font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.card-subtitle{color:var(--text-secondary);font-size:.875rem}.danger-card{border-color:#ef4444}.support-card{border-color:var(--border-color)}.support-icon{background-color:#dc26261a;color:var(--accent-color)}.support-content{padding:.5rem 0}.support-text{color:var(--text-color);font-size:1rem;line-height:1.6;margin:0}.support-email{color:var(--accent-color);font-weight:600;text-decoration:none}.support-email:hover{text-decoration:underline}.danger-section{display:flex;flex-direction:column;gap:1.5rem}.danger-item{align-items:flex-start;background-color:#ef44440d;border:1px solid #ef444433;border-radius:.75rem;display:flex;gap:2rem;justify-content:space-between;padding:1.5rem}.danger-info{flex:1 1}.danger-title{color:#ef4444;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.danger-description{color:var(--text-secondary);line-height:1.5;margin-bottom:1rem}.danger-list{list-style:none;margin:0;padding:0}.danger-list li{color:var(--text-secondary);font-size:.875rem;margin-bottom:.25rem;padding-left:1rem;position:relative}.danger-list li:before{color:#ef4444;content:"•";left:0;position:absolute}.btn-danger{align-items:center;background-color:#ef4444;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease;white-space:nowrap}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-danger:disabled{cursor:not-allowed;opacity:.6}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal{background-color:var(--primary-color);border-radius:1rem;box-shadow:var(--shadow-lg);max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-header{align-items:center;display:flex;gap:1rem;padding:1.5rem 1.5rem 0}.modal-icon{background-color:#ef44441a;border-radius:.5rem;color:#ef4444;height:40px;padding:.5rem;width:40px}.modal-title{color:var(--text-color);font-size:1.25rem;font-weight:600}.modal-body{padding:1.5rem}.modal-warning{background-color:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;color:var(--text-color);font-size:.875rem;line-height:1.5;margin-bottom:1.5rem;padding:1rem}.delete-form{display:flex;flex-direction:column;gap:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding:0 1.5rem 1.5rem}.btn-secondary{background-color:var(--secondary-color);border:1px solid var(--border-color);border-radius:.5rem;color:var(--text-color);cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:all .2s ease}.btn-secondary:hover:not(:disabled){background-color:var(--border-color)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.profile-tabs{flex-direction:column}.tab-button{justify-content:flex-start}.danger-item{flex-direction:column;gap:1rem}.modal{margin:1rem}.modal-actions{flex-direction:column}.btn-danger,.btn-secondary{justify-content:center;width:100%}}.public-portfolio{background:linear-gradient(135deg,var(--secondary-color) 0,var(--primary-color) 100%);min-height:100vh;padding:2rem 0}.portfolio-header{display:flex;justify-content:center;margin-bottom:3rem}.back-button{align-items:center;background:none;border:none;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:2rem;text-decoration:none;transition:color .2s ease}.back-button:hover{color:var(--accent-color)}.portfolio-info{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:1rem;box-shadow:var(--shadow-lg);flex-direction:row;gap:2rem;max-width:800px;padding:2rem;width:100%}.portfolio-info,.user-avatar{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,var(--accent-color),#0f828c);border-radius:50%;box-shadow:var(--shadow);flex-shrink:0;height:100px;justify-content:center;width:100px}.avatar-icon{color:#fff;height:50px;width:50px}.avatar-image{border-radius:50%;display:block;height:100%;object-fit:cover;width:100%}.user-details{flex:1 1}.user-name{color:var(--text-color);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.portfolio-badges{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;margin-top:.5rem}.portfolio-badge{align-items:center;background-color:var(--secondary-color);border:1px solid var(--border-color);border-radius:9999px;color:var(--text-color);display:inline-flex;font-size:.75rem;font-weight:600;padding:.25rem .6rem}.portfolio-badge-total{background-color:#dc26261f;border-color:#dc26264d;color:var(--accent-color)}.portfolio-url{align-items:center;color:var(--text-secondary);display:flex;font-size:1rem;gap:.5rem;margin-bottom:1rem}.portfolio-url .icon{height:16px;width:16px}.copy-url-btn{align-items:center;background:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);cursor:pointer;display:inline-flex;justify-content:center;margin-left:.25rem;padding:.35rem;transition:background .2s,color .2s}.copy-url-btn:hover{background:var(--accent-color);border-color:var(--accent-color);color:#fff}.copy-url-btn .icon{height:16px;width:16px}.stats{display:flex;gap:1.5rem}.stat{align-items:center;color:var(--text-secondary);display:flex;font-size:.875rem;font-weight:500;gap:.5rem}.stat .icon{color:var(--accent-color);height:16px;width:16px}.social-links{display:flex;gap:1rem;margin-top:1rem}.social-link{align-items:center;border:2px solid var(--border-color);border-radius:50%;display:flex;height:40px;justify-content:center;text-decoration:none;transition:all .2s ease;width:40px}.social-link:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.social-link.linkedin{background-color:#0077b5;border-color:#0077b5;color:#fff}.social-link.linkedin:hover{background-color:#005885;border-color:#005885}.social-link.github{background-color:#333;border-color:#333;color:#fff}.social-link.github:hover{background-color:#000;border-color:#000}.social-link.website{background-color:var(--accent-color);border-color:var(--accent-color);color:#fff}.social-link.website:hover{background-color:var(--accent-hover);border-color:var(--accent-hover)}.social-link .icon{height:20px;width:20px}.certifications-section{margin-bottom:3rem}.section-title{color:var(--text-color);font-size:2rem;font-weight:600;margin-bottom:2rem;text-align:center}.section-header-with-sort{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.section-header-with-sort .section-title{margin-bottom:0}.sort-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.sort-label{align-items:center;color:var(--text-secondary);display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem}.sort-select{background:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-color);cursor:pointer;font-size:.875rem;padding:.4rem .6rem}.pagination-controls{align-items:center;border-top:1px solid var(--border-color);display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:2rem;padding-top:1.5rem}.pagination-info{color:var(--text-secondary);font-size:.875rem}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.certifications-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.certification-card-public{align-items:flex-start;background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow);flex-direction:row;gap:1rem;padding:1.5rem;transition:var(--transition)}.certification-card-public:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.certification-card-public-main{flex:1 1;min-width:0}.certification-header{align-items:flex-start;display:flex;gap:1rem;margin-bottom:1rem}.certification-icon{align-items:center;background:#fff;border:2px solid #0f828c;border-radius:var(--radius);display:flex;flex-shrink:0;height:48px;justify-content:center;min-height:48px;min-width:48px;width:48px}.certification-icon .icon{color:var(--accent-color);height:24px;width:24px}.certification-icon .certification-logo-img{height:28px;object-fit:contain;width:28px}.certification-info{flex:1 1;min-width:0}.certification-name{word-wrap:break-word;color:var(--text-color);font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.expiry-status{align-items:center;display:flex;font-size:.75rem;font-weight:600;gap:.25rem}.expiry-status .icon{height:14px;width:14px}.certification-details{display:flex;flex-direction:column;gap:.75rem}.detail-item{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.detail-item .icon{color:var(--text-secondary);flex-shrink:0;height:16px;width:16px}.detail-label{color:var(--text-secondary);font-weight:500;min-width:80px}.detail-value{color:var(--text-color);font-weight:500}.detail-link{color:var(--accent-color);font-weight:500;text-decoration:none}.detail-link:hover{text-decoration:underline}.empty-state{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:1rem;box-shadow:var(--shadow);padding:4rem 2rem;text-align:center}.empty-icon{color:var(--text-secondary);height:64px;margin:0 auto 1.5rem;width:64px}.empty-state h3{color:var(--text-color);font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.empty-state p{color:var(--text-secondary);font-size:1rem}.error,.not-found{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:1rem;box-shadow:var(--shadow);margin:0 auto;max-width:500px;padding:4rem 2rem;text-align:center}.error-icon,.not-found-icon{align-items:center;background-color:#ef44441a;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 2rem;width:80px}.error-icon .icon,.not-found-icon .icon{color:#ef4444;height:40px;width:40px}.error-title,.not-found-title{color:var(--text-color);font-size:2rem;font-weight:700;margin-bottom:1rem}.error-description,.not-found-description{color:var(--text-secondary);font-size:1rem;line-height:1.5;margin-bottom:2rem}.portfolio-footer{background-color:var(--primary-color);border:1px solid var(--border-color);border-radius:1rem;box-shadow:var(--shadow);padding:2rem;text-align:center}.footer-text{color:var(--text-secondary);font-size:.875rem;margin-bottom:1.5rem}.btn-outline{align-items:center;background:#0000;border:1px solid var(--accent-color);border-radius:.5rem;color:var(--accent-color);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .2s ease}.btn-outline:hover{background-color:var(--accent-color);color:#fff}@media (max-width:768px){.public-portfolio{padding:1rem 0}.portfolio-info{flex-direction:column;gap:1.5rem;text-align:center}.user-avatar{height:80px;width:80px}.avatar-icon{height:40px;width:40px}.user-name{font-size:2rem}.certifications-grid{gap:1rem;grid-template-columns:1fr}.certification-card-public{padding:1rem}.certification-header{gap:.75rem}.certification-icon{height:40px;min-height:40px;min-width:40px;width:40px}.certification-icon .icon{height:20px;width:20px}.certification-icon .certification-logo-img{height:22px;width:22px}.certification-name{font-size:1.125rem}.stats{justify-content:center}.portfolio-footer{padding:1.5rem}}@media (max-width:480px){.user-name{font-size:1.75rem}.section-title{font-size:1.5rem}.certification-card-public{padding:.75rem}.certification-name{font-size:1rem}.detail-item{font-size:.8rem}.detail-label{min-width:70px}}.app{background-color:var(--primary-color);color:var(--text-color);min-height:100vh;transition:background-color .3s ease,color .3s ease}.main-content{background:linear-gradient(135deg,var(--secondary-color) 0,var(--primary-color) 100%);min-height:calc(100vh - 80px);padding-top:80px}@media (max-width:768px){.main-content{min-height:calc(100vh - 70px);padding-top:70px}}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{transition:opacity .3s,transform .3s}.page-enter-active,.page-exit{opacity:1;transform:translateY(0)}.page-exit-active{opacity:0;transform:translateY(-20px);transition:opacity .3s,transform .3s}
/*# sourceMappingURL=main.2972cb23.css.map*/