:root{--radius-sm: 12px;--radius-md: 20px;--radius-lg: 28px;--radius-xl: 36px;--shadow-soft: 0 8px 30px rgba(0, 0, 0, .12);--shadow-hover: 0 12px 40px rgba(0, 0, 0, .18);--transition-smooth: all .3s cubic-bezier(.4, 0, .2, 1);--bg-linear-gradient: linear-gradient(90deg, #317AC1 0%, #7C80FC 100%)}[data-bs-theme=light]{--bs-body-bg: #f5f5f7;--card-bg: #ffffff;--card-border: rgba(0, 0, 0, .08);--glass-bg: rgba(255, 255, 255, .7);--text-color: #1c1c1e;--text-color-btn: #ffffff;--text-color-btn-hover: #000000}[data-bs-theme=dark]{--bs-body-bg: #000000;--card-bg: #1c1c1e;--card-border: rgba(255, 255, 255, .1);--glass-bg: rgba(28, 28, 30, .7);--text-color: #f5f5f7;--text-color-btn: #000000;--text-color-btn-hover: #ffffff}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;transition:var(--transition-smooth);min-height:100vh;overflow-x:hidden}.text-gradient{background:var(--bg-linear-gradient);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.navbar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:var(--glass-bg)!important;border-bottom:1px solid var(--card-border);padding:1rem 0;position:sticky;top:0;z-index:1000;transition:var(--transition-smooth)}.navbar-brand{font-weight:600;font-size:1.3rem;letter-spacing:-.5px}.nav-link{font-weight:500;padding:.5rem 1rem!important;border-radius:var(--radius-sm);transition:var(--transition-smooth);margin:0 .25rem}.nav-link:hover{background:var(--card-bg);transform:translateY(-2px)}.nav-link.active{background:var(--bs-primary);color:#fff!important}.theme-toggle{width:44px;height:44px;border-radius:50%;border:2px solid var(--card-border);background:var(--card-bg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth);font-size:1.2rem}.theme-toggle:hover{transform:scale(1.1) rotate(15deg);box-shadow:var(--shadow-soft)}.card-iphone{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);padding:2rem;transition:var(--transition-smooth);box-shadow:var(--shadow-soft);overflow:hidden;position:relative}.card-iphone:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover)}.card-iphone:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--bg-linear-gradient);opacity:0;transition:var(--transition-smooth)}.card-iphone:hover:before{opacity:1}.btn-iphone{background:var(--bs-primary);color:var(--text-color-btn);border:none;border-radius:var(--radius-md);padding:.875rem 2rem;font-weight:600;transition:var(--transition-smooth);box-shadow:0 4px 15px #667eea66}.btn-iphone:hover{transform:translateY(-3px);box-shadow:0 6px 25px #667eea99;color:var(--text-color-btn-hover)}.hero-section{min-height:90vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.hero-section:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(102,126,234,.15) 0%,transparent 70%);border-radius:50%;top:-250px;right:-250px;animation:float 20s ease-in-out infinite}.hero-section:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(118,75,162,.15) 0%,transparent 70%);border-radius:50%;bottom:-200px;left:-200px;animation:float 15s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(0)}50%{transform:translate(50px,50px)}}.section-title{font-size:2.5rem;font-weight:700;margin-bottom:3rem;letter-spacing:-1px;position:relative;display:inline-block}.section-title:after{content:"";position:absolute;bottom:-10px;left:0;width:60px;height:4px;background:var(--bg-linear-gradient);border-radius:2px}.skill-bar{height:12px;background:var(--card-border);border-radius:10px;overflow:hidden;position:relative}.skill-progress{height:100%;background:var(--bg-linear-gradient);border-radius:10px;transition:width 1.5s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.skill-progress:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skill-card{background:var(--card-border);border-radius:var(--radius-md);padding:.875rem;transition:var(--transition-smooth);cursor:default;border:1px solid transparent;height:100%}.skill-card:hover{background:#667eea14;border-color:#667eea33;transform:translateY(-3px);box-shadow:0 4px 16px #667eea26}.skill-card-inner{display:flex;align-items:center;font-size:.875rem;font-weight:500;line-height:1.4}.skill-card-inner i{flex-shrink:0}.skill-card-inner span{word-break:break-word}.tech-logo-card{background:var(--card-border);border-radius:var(--radius-md);padding:1.25rem;transition:var(--transition-smooth);cursor:default;border:1px solid transparent;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.tech-logo-card:hover{background:#667eea14;border-color:#667eea33;transform:translateY(-5px) scale(1.05);box-shadow:0 8px 24px #667eea33}.tech-logo-card i,.tech-logo-card svg{transition:var(--transition-smooth)}.tech-logo-card:hover i,.tech-logo-card:hover svg{transform:scale(1.1)}.rgpd-notice{background:#22c55e0d;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-md);padding:1rem;transition:var(--transition-smooth)}.rgpd-notice:hover{background:#22c55e14;border-color:#22c55e4d}.rgpd-icon{width:40px;height:40px;background:#22c55e1a;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:.75rem}.rgpd-icon i{font-size:1.3rem;color:#22c55e}.rgpd-text{flex:1}.rgpd-text strong{color:#22c55e;font-size:.9rem}.rgpd-text small{line-height:1.6;color:var(--text-color);opacity:.85}.footer{background:var(--card-bg);border-top:1px solid var(--card-border);padding:3rem 0 2rem;margin-top:5rem}.form-control,.form-select{border-radius:var(--radius-sm);border:1px solid var(--card-border);background:var(--card-bg);padding:.875rem 1rem;transition:var(--transition-smooth)}.form-control:focus,.form-select:focus{border-color:var(--bs-primary);box-shadow:0 0 0 .25rem #667eea26}.timeline-item{position:relative;padding-left:40px;margin-bottom:2rem}.timeline-item:before{content:"";position:absolute;left:0;top:8px;width:16px;height:16px;background:var(--bs-primary);border-radius:50%;box-shadow:0 0 0 4px var(--card-bg),0 0 0 6px var(--card-border)}.timeline-item:after{content:"";position:absolute;left:7.5px;top:28px;width:1px;height:calc(100% + 10px);background:var(--card-border)}.timeline-item:last-child:after{display:none}@media(max-width:768px){.section-title{font-size:2rem}.hero-section{min-height:70vh}.card-iphone{padding:1.5rem}}.fade-in{animation:fadeIn .6s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.blog-filter-btn{padding:.5rem 1.5rem;border-radius:var(--radius-md);border:1px solid var(--card-border);background:var(--card-bg);color:inherit;font-weight:500;transition:var(--transition-smooth);cursor:pointer}.blog-filter-btn:hover{border-color:#667eea4d;background:#667eea0d}.blog-filter-btn.active{background:var(--bg-linear-gradient);color:#fff;border-color:transparent}.blog-card{background:var(--card-bg);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition-smooth);height:100%;display:flex;flex-direction:column;box-shadow:var(--shadow-soft);border:1px solid var(--card-border)}.blog-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover)}.blog-card-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.blog-card-image{position:relative;width:100%;height:220px;overflow:hidden}.blog-card-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition-smooth)}.blog-card:hover .blog-card-image img{transform:scale(1.05)}.blog-card-category{position:absolute;top:1rem;right:1rem;background:#667eeaf2;color:#fff;padding:.375rem .875rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.blog-card-content{padding:1.5rem;flex:1;display:flex;flex-direction:column}.blog-card-meta{display:flex;gap:1rem;font-size:.85rem;color:#999;margin-bottom:1rem}.blog-card-meta i{margin-right:.25rem}.blog-card-title{font-size:1.25rem;font-weight:700;margin-bottom:.75rem;line-height:1.4}.blog-card-excerpt{color:#999;font-size:.95rem;line-height:1.6;margin-bottom:1rem;flex:1}.blog-card-tags{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}.blog-tag{background:var(--card-border);padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:500}.blog-card-footer{padding-top:1rem;border-top:1px solid var(--card-border)}.blog-read-more{color:#317ac1;font-weight:600;display:inline-flex;align-items:center;transition:var(--transition-smooth)}.blog-card:hover .blog-read-more i{transform:translate(5px)}.article-category{background:var(--bg-linear-gradient);color:#fff;padding:.5rem 1.5rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;display:inline-block}.article-title{font-size:2.5rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.article-meta{font-size:.95rem;color:#999}.article-meta i{margin-right:.25rem}.article-tag{background:var(--card-border);padding:.375rem .875rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;display:inline-block;margin:0 .25rem}.article-image{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-soft)}.article-image img{width:100%;height:auto;display:block}.article-content{font-size:1.1rem;line-height:1.8}.article-content p{margin-bottom:1.5rem}.article-content h2{font-size:1.75rem;font-weight:700;margin-top:3rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--card-border)}.article-content h3{font-size:1.5rem;font-weight:600;margin-top:2rem;margin-bottom:1rem}.article-content ul,.article-content ol{margin-bottom:1.5rem;padding-left:2rem}.article-content li{margin-bottom:.5rem}.article-content .lead{font-size:1.3rem;line-height:1.7;color:#666;margin-bottom:2rem;padding:1.5rem;background:var(--card-border);border-left:4px solid #317AC1;border-radius:var(--radius-md)}.code-block{background:#282c34;border-radius:var(--radius-md);margin:2rem 0;overflow:hidden}.code-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#21252b;border-bottom:1px solid #181a1f}.code-language{color:#abb2bf;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.code-copy-btn{background:transparent;border:1px solid #4b5563;color:#abb2bf;padding:.375rem .875rem;border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.code-copy-btn:hover{background:#4b5563;color:#fff}.code-copy-btn.copied{background:#22c55e;border-color:#22c55e;color:#fff}.code-block pre{margin:0;padding:1.5rem;overflow-x:auto}.code-block code{font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.9rem;line-height:1.6}.alert-box{display:flex;align-items:start;padding:1.25rem;border-radius:var(--radius-md);margin:2rem 0;border-left:4px solid}.alert-icon{font-size:1.5rem;margin-right:1rem;flex-shrink:0}.alert-content{flex:1}.alert-content strong{display:block;margin-bottom:.25rem}.alert-box-info{background:#3b82f61a;border-left-color:#3b82f6}.alert-box-info .alert-icon{color:#3b82f6}.alert-box-warning{background:#fb923c1a;border-left-color:#fb923c}.alert-box-warning .alert-icon{color:#fb923c}.alert-box-success{background:#22c55e1a;border-left-color:#22c55e}.alert-box-success .alert-icon{color:#22c55e}.article-screenshot{margin:2rem 0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-soft)}.article-screenshot img{width:100%;height:auto;display:block}.screenshot-caption{background:var(--card-border);padding:1rem;font-size:.9rem;color:#999;text-align:center;margin:0}.article-navigation{margin-top:4rem;padding-top:2rem;border-top:2px solid var(--card-border)}.btn-article-back{display:inline-flex;align-items:center;padding:.875rem 1.75rem;background:var(--bg-linear-gradient);color:#fff;border-radius:var(--radius-md);text-decoration:none;font-weight:600;transition:var(--transition-smooth);box-shadow:0 4px 12px #667eea4d}.btn-article-back:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66;color:#fff}@media(max-width:768px){.article-title{font-size:2rem}.article-content{font-size:1rem}.article-content .lead{font-size:1.1rem}}.nav-auth-link{background:linear-gradient(135deg,#317ac1,#7c80fc);color:#fff!important;border-radius:var(--radius-sm);padding:.5rem 1rem!important;font-weight:500;transition:var(--transition-smooth)}.nav-auth-link:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66;background:linear-gradient(135deg,#317ac1,#7c80fc)!important}.user-dropdown-toggle{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem!important;border-radius:var(--radius-sm);background:var(--card-bg);border:1px solid var(--card-border)}.user-dropdown-toggle:hover{background:var(--card-bg)}.user-dropdown-toggle:after{margin-left:.25rem;font-size:.7rem}.user-avatar-nav{width:32px;height:32px;border-radius:50%;object-fit:cover}.user-name-nav{font-weight:500;font-size:.9rem;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown-menu{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-md);box-shadow:var(--shadow-soft);padding:.5rem;min-width:240px;margin-top:.5rem!important}.user-dropdown-menu .dropdown-header{padding:.75rem;background:transparent}.user-info-header{display:flex;align-items:center;gap:.75rem}.user-avatar-dropdown{width:48px;height:48px;border-radius:50%;object-fit:cover}.user-name-dropdown{font-weight:600;font-size:.95rem;color:var(--text-color)}.user-email-dropdown{font-size:.8rem;color:var(--bs-secondary);opacity:.8}.user-dropdown-menu .dropdown-divider{margin:.5rem 0;border-color:var(--card-border)}.user-dropdown-menu .dropdown-item{padding:.6rem .75rem;border-radius:var(--radius-sm);font-weight:500;display:flex;align-items:center;transition:var(--transition-smooth)}.user-dropdown-menu .dropdown-item:hover{background:#667eea1a}.user-dropdown-menu .dropdown-item.text-danger:hover{background:#dc35451a}@media(max-width:991px){.user-dropdown-toggle{justify-content:flex-start;width:100%;margin-top:.5rem}.user-name-nav{display:inline!important}.user-dropdown-menu{position:static!important;transform:none!important;width:100%;margin-top:.25rem!important;box-shadow:none;border:1px solid var(--card-border)}}.cookie-toast{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%) translateY(100px);z-index:9999;width:calc(100% - 2rem);max-width:600px;opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.cookie-toast.show{transform:translate(-50%) translateY(0);opacity:1;pointer-events:auto}.cookie-toast-content{background:var(--card-bg);border:1px solid var(--card-border);border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000026;padding:1.25rem;display:flex;align-items:flex-start;gap:1rem}[data-bs-theme=dark] .cookie-toast-content{box-shadow:0 10px 40px #0006}.cookie-toast-icon{width:44px;height:44px;min-width:44px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.25rem}.cookie-toast-text{flex:1}.cookie-toast-text strong{display:block;color:var(--text-color);font-size:.95rem;margin-bottom:.35rem}.cookie-toast-text p{color:var(--text-color);opacity:.7;font-size:.85rem;line-height:1.5;margin:0}.cookie-toast-btn{background:linear-gradient(135deg,#317ac1,#7c80fc);border:none;color:#fff;padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;cursor:pointer;transition:var(--transition-smooth);white-space:nowrap;display:flex;align-items:center}.cookie-toast-btn:hover{transform:translateY(-2px);box-shadow:0 4px 15px #667eea66}.cookie-toast-btn:active{transform:translateY(0)}@media(max-width:576px){.cookie-toast{bottom:1rem;width:calc(100% - 1rem)}.cookie-toast-content{flex-direction:column;text-align:center;padding:1rem;gap:.75rem}.cookie-toast-icon{margin:0 auto}.cookie-toast-btn{width:100%;justify-content:center}}
