*{margin:0;padding:0}section{background:#f8fafc;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:80px 20px;display:flex}section h2{color:#0f172a;margin-bottom:30px}section form .input-group{flex-direction:column;gap:8px;display:flex}section form input[type=text],section form textarea{background:#fff;border:1px solid #e2e8f0;border-radius:12px;width:100%;padding:12px 16px;font-size:1rem;transition:all .3s;box-shadow:inset 0 2px 4px #0000000f}section form input[type=text]:focus,section form textarea:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}section form textarea{resize:vertical;min-height:120px}section form input[type=file]{cursor:pointer;padding:10px 0}section form input[type=file]::file-selector-button{color:#0f172a;cursor:pointer;transition:.3 all;background-color:#f8fafc;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}section form input[type=file]::file-selector-button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}section form input[type=file]::file-selector-button:active{transform:translateY(0)}section form input[type=file]::file-selector-button{border:1px solid #e2e8f0;margin-right:15px;padding:8px 16px}section form button[type=submit]{margin-top:10px;font-size:1.1rem;box-shadow:0 4px 14px #2563eb63}.login-container{background-color:#f8fafc;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-container .login-card{background:#fff;border-radius:12px;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:25px;width:100%;max-width:400px;padding:40px;display:flex;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.login-container .login-card header{text-align:center}.login-container .login-card header h1{color:#0f172a;margin-bottom:8px;font-size:1.8rem}.login-container .login-card header p{color:#475569;font-size:.9rem}.login-container .login-card form{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:20px;display:flex}.login-container .login-card form .input-group{flex-direction:column;gap:8px;display:flex}.login-container .login-card form .input-group label{color:#0f172a;font-size:.85rem;font-weight:600}.login-container .login-card form .input-group input{width:100%;transition:.3 all;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:12px 16px;font-size:1rem;box-shadow:inset 0 2px 4px #0000000f}.login-container .login-card form .input-group input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.login-container .login-card form button[type=submit]{color:#fff;cursor:pointer;transition:.3 all;background-color:#2563eb;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}.login-container .login-card form button[type=submit]:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.login-container .login-card form button[type=submit]:active{transform:translateY(0)}.login-container .login-card form button[type=submit]{margin-top:10px;padding:14px;font-size:1rem;box-shadow:0 4px 14px #2563eb63}.login-container .login-card form button[type=submit]:disabled{cursor:not-allowed;box-shadow:none;transform:none;background-color:#e2e8f0!important}section{background-color:#f8fafc;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:60px 20px;display:flex}section h2{color:#0f172a;margin-bottom:40px;font-size:2rem;font-weight:700;position:relative}section h2:after{content:"";background:#2563eb;border-radius:9999px;width:50px;height:4px;position:absolute;bottom:-10px;left:50%;transform:translate(-50%)}section form{background:#fff;border-radius:12px;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:25px;width:100%;max-width:650px;padding:40px;display:flex;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}section form .input-group{flex-direction:column;justify-content:flex-start;align-items:stretch;gap:10px;display:flex}section form .input-group label{color:#0f172a;font-size:.95rem;font-weight:600}section form .input-group input[type=text],section form .input-group textarea{width:100%;transition:.3 all;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:14px 18px;font-size:1rem;box-shadow:inset 0 2px 4px #0000000f}section form .input-group input[type=text]:focus,section form .input-group textarea:focus{background:#fff;border-color:#2563eb;outline:none;box-shadow:0 0 0 4px #2563eb1a}section form .input-group textarea{resize:vertical;min-height:150px}section form .input-group input[type=file]{cursor:pointer;transition:.3 all;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:8px;padding:15px}section form .input-group input[type=file]:hover{border-color:#2563eb}section form .input-group input[type=file]::file-selector-button{color:#2563eb;cursor:pointer;transition:.3 all;background-color:#eff6ff;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}section form .input-group input[type=file]::file-selector-button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}section form .input-group input[type=file]::file-selector-button:active{transform:translateY(0)}section form .input-group input[type=file]::file-selector-button{border:none;margin-right:15px;padding:8px 15px;font-size:.85rem}section form .input-group small{color:#475569;margin-top:-5px;font-size:.8rem}section form button[type=submit]{color:#fff;cursor:pointer;transition:.3 all;background-color:#2563eb;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}section form button[type=submit]:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}section form button[type=submit]:active{transform:translateY(0)}section form button[type=submit]{margin-top:15px;padding:16px;font-size:1.1rem;font-weight:600;box-shadow:0 4px 14px #2563eb63}section form button[type=submit]:disabled{cursor:not-allowed;box-shadow:none;transform:none;background-color:#e2e8f0!important}.admin-sidebar{background:linear-gradient(#fff,#f8fafc);border-right:1px solid #0f141e0d;flex-direction:column;flex:0 0 260px;gap:.6rem;width:260px;padding:1.1rem .9rem;display:flex;box-shadow:0 6px 20px #0a0f1908}.admin-sidebar .brand{color:#0b3a66;letter-spacing:-.02em;padding:.45rem .6rem;font-size:1.05rem;font-weight:900}.side-nav{flex:auto;margin-top:.6rem}.side-nav ul{flex-direction:column;gap:.35rem;margin:0;padding:0;list-style:none;display:flex}.side-nav a{color:#0f172a;border-radius:10px;align-items:center;gap:.9rem;padding:.7rem .65rem;font-weight:700;text-decoration:none;transition:background .16s,transform .12s;display:flex}.side-nav a .icon{color:#475569;justify-content:center;align-items:center;display:inline-flex}.side-nav a:hover{background:#0b76ff0a;transform:translate(2px)}.side-nav a.active{color:#06213a;background:linear-gradient(90deg,#0b76ff1a,#7c3aed0a);box-shadow:inset 4px 0 #0b76ff1f}.sidebar-footer{padding:.6rem}.logout-btn{color:#ef4444;background:0 0;border:0;border-radius:8px;align-items:center;gap:.6rem;padding:.5rem .6rem;font-weight:700;display:flex}.admin-sidebar.compact{width:76px}.admin-sidebar.compact .label{display:none}@media (width<=900px){.admin-sidebar{z-index:40;transition:transform .22s;position:fixed;top:0;bottom:0;left:0;transform:translate(-110%)}.admin-sidebar.open{transform:translate(0)}}.blog-form{flex-direction:column;gap:12px;padding:8px;display:flex}.blog-form label{color:#0f172a;flex-direction:column;font-weight:600;display:flex}.blog-form input[type=file]{margin-top:6px}.form-error{color:#b91c1c;background:#f973160f;border-radius:6px;padding:8px}.form-actions{justify-content:flex-end;gap:10px;margin-top:6px;display:flex}.btn{cursor:pointer;border:0;border-radius:8px;padding:8px 12px}.btn-muted{background:#f3f4f6}.btn-primary{color:#fff;background:linear-gradient(90deg,#0b76ff,#7c3aed)}@media (width<=720px){.form-actions{flex-direction:column;align-items:stretch}}.dashboard-root{align-items:flex-start;width:100%;min-height:100vh;display:flex}.dashboard-container{background-color:#f8fafc;flex-direction:column;flex:auto;justify-content:flex-start;align-items:stretch;min-height:100vh;margin-top:68px;padding:40px;display:flex}.dashboard-container .dashboard-header{flex-direction:row;justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}.dashboard-container .dashboard-header .header-left{align-items:center;gap:12px;display:flex}.dashboard-container .dashboard-header .menu-toggle{cursor:pointer;background:0 0;border:0;border-radius:8px;padding:6px;display:none}@media (width<=900px){.dashboard-container .dashboard-header .menu-toggle{display:inline-flex}}.dashboard-container .dashboard-header h1{color:#0f172a;font-size:1.8rem}.dashboard-container .dashboard-header p{color:#475569}.dashboard-container .dashboard-header .header-actions{align-items:center;gap:10px;display:flex}.dashboard-container .dashboard-header .add-btn{color:#fff;cursor:pointer;transition:.3 all;background-color:#2563eb;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}.dashboard-container .dashboard-header .add-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.dashboard-container .dashboard-header .add-btn:active{transform:translateY(0)}.dashboard-container .dashboard-header .add-btn{flex-direction:row;justify-content:center;align-items:center;gap:8px;padding:10px 20px;display:flex}.dashboard-container .dashboard-header .add-btn.secondary{color:#0f172a;background:0 0;border:1px solid #0f141e0f;padding:8px 14px}.dashboard-container .table-section{background:#fff;border-radius:12px;align-items:flex-start;width:100%;margin-top:0;display:block;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.dashboard-container .table-section .project-table{border-collapse:collapse;text-align:left;width:100%}.dashboard-container .table-section .project-table thead{background:#f8fafc}.dashboard-container .table-section .project-table thead tr th{color:#0f172a;border-bottom:1px solid #e2e8f0;padding:15px 20px;font-weight:600}.dashboard-container .table-section .project-table tbody tr{transition:.3 all;border-bottom:1px solid #e2e8f0}.dashboard-container .table-section .project-table tbody tr:hover{background:#f8fafc80}.dashboard-container .table-section .project-table tbody tr td{vertical-align:middle;color:#0f172a;padding:15px 20px}.dashboard-container .table-section .project-table tbody tr td .table-img{object-fit:cover;border-radius:8px;width:60px;height:40px}.dashboard-container .table-section .project-table tbody tr td .tech-tags{flex-wrap:wrap;gap:5px;display:flex}.dashboard-container .table-section .project-table tbody tr td .tech-tags .tag{color:#2563eb;background:#eff6ff;border-radius:9999px;padding:2px 8px;font-size:.75rem;font-weight:500}.dashboard-container .table-section .project-table tbody tr td.actions{gap:10px;display:flex}.dashboard-container .table-section .project-table tbody tr td.actions button{cursor:pointer;transition:.3 all;background:0 0;border:none;border-radius:8px;padding:8px}.dashboard-container .table-section .project-table tbody tr td.actions button.edit-icon{color:#3b82f6}.dashboard-container .table-section .project-table tbody tr td.actions button.edit-icon:hover{background:#eff6ff}.dashboard-container .table-section .project-table tbody tr td.actions button.delete-icon{color:#ef4444}.dashboard-container .table-section .project-table tbody tr td.actions button.delete-icon:hover{background:#fef2f2}@media (width<=900px){.dashboard-root{position:relative}.dashboard-container{padding:20px}}.modal-overlay{z-index:1000;background:#00000080;flex-direction:row;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;display:flex;position:fixed;top:0;left:0}.modal-overlay .modal-content{background:#fff;border-radius:12px;width:100%;max-width:700px;max-height:90vh;padding:30px;position:relative;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-overlay .modal-content .close-btn{cursor:pointer;color:#475569;background:0 0;border:none;position:absolute;top:15px;right:15px}.modal-overlay .modal-content .close-btn:hover{color:#2563eb}.skeleton{--skeleton-base:#e8eef7;--skeleton-highlight:#f7fbff;--skeleton-border:#94a3b838;border:1px solid var(--skeleton-border);background:#ffffffad;border-radius:12px;position:relative;overflow:hidden}.skeleton-line,.skeleton-media,.skeleton-pills span,.screenshots-skeleton div{background:var(--skeleton-base);border-radius:8px;display:block;position:relative;overflow:hidden}.skeleton-line:after,.skeleton-media:after,.skeleton-pills span:after,.screenshots-skeleton div:after{content:"";background:linear-gradient(90deg,#0000,#ffffffc7,#0000);animation:1.35s ease-in-out infinite skeleton-shimmer;position:absolute;inset:0;transform:translate(-100%)}.skeleton-line{width:72%;height:14px}.skeleton-line.wide{width:90%}.skeleton-line.short{width:46%}.skeleton-line.button{border-radius:8px;width:118px;height:38px}.skeleton-line.date{width:145px}.skeleton-row{justify-content:space-between;align-items:center;gap:16px;width:100%;display:flex}.skeleton-content{flex-direction:column;gap:14px;padding:20px;display:flex}.skeleton-pills{flex-wrap:wrap;gap:10px;display:flex}.skeleton-pills.centered{justify-content:center}.skeleton-pills span{border-radius:999px;width:74px;height:24px}.project-card-skeleton,.blog-card-skeleton{min-height:330px;box-shadow:0 8px 30px #0c12280f}.project-card-skeleton .skeleton-media{aspect-ratio:16/10;margin:20px 20px 0}.project-card-skeleton .skeleton-content{align-items:center}.project-card-skeleton .skeleton-line.wide{max-width:260px}.blog-card-skeleton{opacity:0;animation:.52s cubic-bezier(.2,.9,.2,1) forwards skeleton-fade-up}.blog-card-skeleton .skeleton-media{border-radius:0;width:100%;height:180px}.blog-card-skeleton .skeleton-row{border-top:1px solid #0f141e0b;margin-top:10px;padding-top:14px}.skeleton-page{background:0 0;border:0;overflow:visible}.details-hero-skeleton{flex-direction:column;gap:16px;max-width:920px;margin:0 auto 1.6rem;padding:1.25rem;display:flex;box-shadow:0 8px 30px #080c180f}.details-hero-skeleton .title{width:84%;max-width:720px;height:34px}.details-hero-skeleton .subtitle{width:58%}.details-body-skeleton{align-items:stretch}.skeleton-hero-image{height:420px}.skeleton-article-copy{flex-direction:column;gap:16px;padding:26px;display:flex}.skeleton-project-details{overflow:visible}.skeleton-project-details .project-title{width:72%;max-width:640px;height:46px;margin:0 auto 18px}.screenshots-skeleton{margin:40px 0;padding:16px}.screenshots-skeleton div{aspect-ratio:16/8;border-radius:12px;width:100%}.skeleton-actions{justify-content:center;gap:20px;display:flex}.description-skeleton{flex-direction:column;gap:16px;margin-top:20px;padding:40px;display:flex}.description-skeleton .heading{width:260px;height:28px}.table-skeleton{flex-direction:column;gap:12px;padding:10px 0;display:flex}.table-skeleton-row{border-bottom:1px solid #e2e8f0e6;grid-template-columns:1fr 120px;align-items:center;gap:18px;padding:14px 16px;display:grid}.table-skeleton-row:has(.table-cell+.table-cell+.table-action){grid-template-columns:1fr 1fr 120px}.table-skeleton .table-cell{width:min(100%,360px)}.table-skeleton .table-action{justify-self:end;width:82px}@keyframes skeleton-shimmer{to{transform:translate(100%)}}@keyframes skeleton-fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (width<=880px){.skeleton-hero-image{height:260px}}@media (width<=600px){.skeleton-row{flex-direction:column;align-items:flex-start}:is(.table-skeleton-row,.table-skeleton-row:has(.table-cell+.table-cell+.table-action)){grid-template-columns:1fr}.table-skeleton .table-action{justify-self:start}}.main-header{width:100%}.main-header .menu-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:99998;background:#0000004d;width:100vw;height:100vh;position:fixed;top:0;left:0}.main-header .navbar-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:99999;background:#ffffffd9;justify-content:space-between;align-items:center;width:100%;height:70px;padding:0 5%;display:flex;position:fixed;top:0;left:0;box-shadow:0 4px 30px #0000000d}.main-header .navbar-container .nav-left .logo{color:#1a1a1a;font-size:1.4rem;font-weight:800}.main-header .navbar-container .nav-left .logo span{color:#2563eb}.main-header .navbar-container .navLinks ul{gap:30px;margin:0;padding:0;transition:all .4s cubic-bezier(.4,0,.2,1);display:flex}.main-header .navbar-container .navLinks ul li{list-style:none}.main-header .navbar-container .navLinks ul li a{color:#4b5563;padding:8px 0;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .3s;position:relative}.main-header .navbar-container .navLinks ul li a:after{content:"";background:#2563eb;width:0;height:2px;transition:all .3s;position:absolute;bottom:0;left:0}.main-header .navbar-container .navLinks ul li a:hover,.main-header .navbar-container .navLinks ul li a.active{color:#2563eb}.main-header .navbar-container .navLinks ul li a:hover:after,.main-header .navbar-container .navLinks ul li a.active:after{width:100%}@media (width<=740px){.main-header .navbar-container .navLinks ul{z-index:100000;background:#fff;flex-direction:column;justify-content:flex-start;align-items:center;gap:35px;width:calc(100% - 100px);height:100vh;padding-top:60px;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:10px 0 30px #0000001a}}.main-header .navbar-container .navLinks .mobile-active{transform:translate(0)!important}.main-header .navbar-container .nav-right{z-index:100001}.main-header .navbar-container .nav-right .menu-trigger{cursor:pointer;color:#1a1a1a;margin-right:40px;display:none}@media (width<=740px){.main-header .navbar-container .nav-right .menu-trigger{display:flex}}.card-body{transition:.3 all;background:#f8fafc;border:1px solid #e2e8f0;border-radius:4px;padding:20px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.card-body:hover{border-color:#0000;transform:translateY(-5px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card-body{-webkit-backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #ffffff4d;flex-direction:column;justify-content:center;align-items:center;display:flex}.card-body .card-top{max-width:400px}.card-body .card-top img{border-radius:20px;width:100%;max-width:400px}.card-body .card-top img :hover{border:none}.card-body .card-bottom{flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex}.card-body .card-bottom .techStack{flex-direction:row;justify-content:center;align-items:center;gap:20px;display:flex}.card-body .card-bottom .techStack li{color:#475569;background:#22c55e;border-radius:5px;padding:2px;font-size:12px;list-style:none}.card-body .card-bottom button{color:#0f172a;cursor:pointer;transition:.3 all;background-color:#2563eb;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}.card-body .card-bottom button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.card-body .card-bottom button:active{transform:translateY(0)}.hero-section{background-color:#eff6ff;background-image:radial-gradient(#2563eb .5px,#0000 .5px);background-size:30px 30px}.hero-section .container{width:90%;max-width:1200px;margin:0 auto}.hero-section .hero-content{text-align:center;max-width:800px;margin:0 auto}.hero-section .hero-content .welcome-text{color:#2563eb;text-transform:uppercase;letter-spacing:2px;margin-bottom:15px;font-weight:600;display:block}.hero-section .hero-content h1{color:#0f172a;margin-bottom:20px;font-size:clamp(2.5rem,5vw,4rem);line-height:1.2}.hero-section .hero-content h1 span{color:#2563eb}.hero-section .hero-content p{color:#475569;margin-bottom:40px;font-size:1.2rem;line-height:1.6}.hero-section .hero-content .hero-btns{justify-content:center;gap:20px;display:flex}@media (width<=480px){.hero-section .hero-content .hero-btns{flex-direction:column}}.hero-section .hero-content .hero-btns .btn-primary{color:#fff;cursor:pointer;transition:.3 all;background-color:#2563eb;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}.hero-section .hero-content .hero-btns .btn-primary:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.hero-section .hero-content .hero-btns .btn-primary:active{transform:translateY(0)}.hero-section .hero-content .hero-btns .btn-primary{padding:15px 35px;font-size:1.1rem}.hero-section .hero-content .hero-btns .btn-outline{color:#fff;cursor:pointer;transition:.3 all;background-color:#0000;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}.hero-section .hero-content .hero-btns .btn-outline:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.hero-section .hero-content .hero-btns .btn-outline:active{transform:translateY(0)}.hero-section .hero-content .hero-btns .btn-outline{color:#2563eb;border:2px solid #2563eb;padding:15px 35px;font-size:1.1rem}.hero-section .hero-content .hero-btns .btn-outline:hover{color:#fff;background-color:#2563eb}.projects-section{background-color:none;padding:60px 0}.projects-section .container{width:calc(100% - 200px);margin:0 auto;padding:0 20px}.projects-section .section-header{text-align:center;margin-bottom:50px}.projects-section .section-header h2{color:#0f172a;margin-bottom:10px;font-size:2rem;font-weight:700}.projects-section .section-header p{color:#475569;font-size:1.1rem}.projects-section .projects-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));justify-content:center;gap:20px;width:100%;display:grid}@media (width<=768px){.projects-section .projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}}.projects-section .no-projects{flex-direction:row;justify-content:center;align-items:center;width:100%;min-height:200px;display:flex}.projects-section .no-projects p{color:#475569;border:1px dashed #475569;border-radius:8px;padding:20px 40px;font-size:1.2rem}.home-about{width:fit-content;height:max-content;min-height:auto;max-height:fit-content;margin:0 auto}.home-about .about-container{background:#f8fafc;height:fit-content;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.about-wrapper{justify-content:space-around;align-items:center;gap:50px;height:fit-content;display:flex}@media (width<=768px){.about-wrapper{text-align:center;flex-direction:column}}.about-wrapper .about-image img{filter:grayscale();border-radius:20px;width:100%;max-width:350px}.about-wrapper .about-image img:hover,.about-wrapper .about-image img:active{filter:grayscale(0%)}.about-wrapper .about-content{gap:20px;max-width:500px}.about-wrapper .about-content button{color:#0f172a;cursor:pointer;transition:.3 all;background-color:#2563eb;border:none;border-radius:8px;padding:10px 24px;font-weight:600;box-shadow:0 1px 2px #0000000d}.about-wrapper .about-content button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.about-wrapper .about-content button:active{transform:translateY(0)}.about-wrapper .about-content button{margin-top:20px}.footer{background-color:#4b4b4b;border-top:1px solid #0000000d;width:100%;padding:40px 0 20px}.footer .container{width:90%;max-width:1200px;margin:0 auto}.footer .footer-content{justify-content:space-between;align-items:center;margin-bottom:30px;display:flex}@media (width<=768px){.footer .footer-content{text-align:center;flex-direction:column;gap:20px}}.footer .footer-content .footer-logo h3{margin-bottom:5px;font-size:1.5rem}.footer .footer-content .footer-logo h3 span{color:#2563eb}.footer .footer-content .footer-logo p{color:#eff6ff;font-size:.9rem}.footer .footer-content .footer-socials{gap:20px;display:flex}.footer .footer-content .footer-socials a{color:#0f172a;font-size:1.2rem;transition:color .3s}.footer .footer-content .footer-socials a:hover{color:#2563eb}.footer .footer-bottom{color:#eff6ff;border-top:1px solid #0000000d;justify-content:space-between;align-items:center;padding-top:20px;font-size:.85rem;display:flex}@media (width<=768px){.footer .footer-bottom{flex-direction:column-reverse;gap:15px}}.footer .footer-bottom .footer-links{gap:20px;display:flex}.footer .footer-bottom .footer-links a{color:#eff6ff;text-decoration:none}.footer .footer-bottom .footer-links a:hover{color:#0f172a}.about-page{background-color:#f8fafc;padding:100px 0;overflow-x:hidden}.about-page .container{width:90%;max-width:1100px;margin:0 auto}.about-page .about-intro{align-items:center;gap:60px;margin-bottom:120px;display:flex}@media (width<=768px){.about-page .about-intro{text-align:center;flex-direction:column}}.about-page .about-intro .text-side{flex:1}.about-page .about-intro .text-side .badge{color:#2563eb;letter-spacing:2px;text-transform:uppercase;font-size:.9rem;font-weight:700}.about-page .about-intro .text-side h1{color:#0f172a;margin:20px 0;font-size:3rem}.about-page .about-intro .text-side h1 span{color:#2563eb}.about-page .about-intro .text-side p{color:#475569;margin-bottom:30px;font-size:1.1rem;line-height:1.8}.about-page .about-intro .text-side .info-grid{grid-template-columns:1fr 1fr;gap:15px;display:grid}.about-page .about-intro .text-side .info-grid .info-item{color:#0f172a;font-size:.95rem}.about-page .about-intro .image-side{flex:.8}.about-page .about-intro .image-side .img-wrapper{position:relative}.about-page .about-intro .image-side .img-wrapper:before{content:"";z-index:-1;background:#2563eb;border:2px solid #2563eb;border-radius:20px;width:100%;height:100%;position:absolute;top:20px;left:20px}.about-page .about-intro .image-side .img-wrapper img{background-color:#ddd;border-radius:20px;width:100%;max-width:500px;display:block}.about-page .skills-section{max-height:fit-content;margin-bottom:100px}.about-page .skills-section h2{text-align:center;margin-bottom:50px;font-size:2.2rem}.about-page .skills-section .skills-grid{grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:40px;display:grid}.about-page .skills-section .skills-grid .skill-item .skill-labels{justify-content:space-between;margin-bottom:10px;font-weight:600;display:flex}.about-page .skills-section .skills-grid .skill-item .bar-bg{background:#e0e0e0;border-radius:10px;height:8px;overflow:hidden}.about-page .skills-section .skills-grid .skill-item .bar-bg .bar-fill{background:#2563eb;border-radius:10px;height:100%}.about-page .journey-box{color:#fff;text-align:center;background:#2563eb;border-radius:30px;max-width:fit-content;height:fit-content;max-height:fit-content;margin:auto;padding:60px}.about-page .journey-box .journey-content{max-width:fit-content;max-height:fit-content}.about-page .journey-box h3{margin-bottom:20px;font-size:2rem}.about-page .journey-box p{opacity:.9;max-width:800px;margin:0 auto;font-size:1.2rem}.services-page{background-color:#f8fafc;padding:100px 0}.services-page .container{width:90%;max-width:1200px;margin:0 auto}.services-page .services-header{text-align:center;margin-bottom:60px}.services-page .services-header .badge{color:#2563eb;text-transform:uppercase;letter-spacing:2px;font-size:.9rem;font-weight:700}.services-page .services-header h1{margin:15px 0;font-size:3rem}.services-page .services-header h1 span{color:#2563eb}.services-page .services-header p{color:#475569;max-width:600px;margin:0 auto;line-height:1.6}.services-page .services-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;display:grid}.services-page .services-grid .service-card{background:#fff;border-bottom:4px solid #0000;border-radius:20px;padding:40px 30px;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 10px 30px #0000000d}.services-page .services-grid .service-card:hover{border-bottom:4px solid #2563eb;box-shadow:0 15px 40px #0000001a}.services-page .services-grid .service-card .icon-box{color:#2563eb;margin-bottom:20px;font-size:2.5rem;display:inline-block}.services-page .services-grid .service-card h3{color:#0f172a;margin-bottom:15px;font-size:1.4rem}.services-page .services-grid .service-card p{color:#475569;margin-bottom:25px;font-size:.95rem;line-height:1.7}.services-page .services-grid .service-card .card-footer{color:#aaa;border-top:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding-top:15px;font-size:.8rem;font-weight:600;display:flex}.services-page .services-grid .service-card .card-footer .dot-loader{background:#2563eb;border-radius:50%;width:8px;height:8px;box-shadow:0 0 10px #2563eb}.contact-page{background-color:#f8fafc;padding:100px 0}.contact-page .container{width:90%;max-width:1100px;margin:0 auto}.contact-page .contact-header{text-align:center;margin-bottom:60px}.contact-page .contact-header .badge{color:#2563eb;letter-spacing:2px;font-weight:700}.contact-page .contact-header h1{color:#0f172a;margin:15px 0;font-size:3rem}.contact-page .contact-header h1 span{color:#2563eb}.contact-page .contact-header p{color:#475569}.contact-page .contact-wrapper{gap:50px;display:flex}@media (width<=850px){.contact-page .contact-wrapper{flex-direction:column}}.contact-page .contact-wrapper .contact-info{flex-direction:column;flex:1;gap:30px;display:flex}.contact-page .contact-wrapper .contact-info .info-card{background:#fff;border-radius:15px;align-items:center;gap:20px;padding:25px;display:flex;box-shadow:0 5px 20px #0000000d}.contact-page .contact-wrapper .contact-info .info-card .icon-box{color:#2563eb;font-size:1.8rem}.contact-page .contact-wrapper .contact-info .info-card h4{color:#0f172a;margin-bottom:5px}.contact-page .contact-wrapper .contact-info .info-card p{color:#475569;margin:0}.contact-page .contact-wrapper .contact-info .social-links{margin-top:20px}.contact-page .contact-wrapper .contact-info .social-links h3{color:#0f172a;margin-bottom:20px;font-size:1.5rem}.contact-page .contact-wrapper .contact-info .social-links .links{gap:15px;display:flex}.contact-page .contact-wrapper .contact-info .social-links .links a{color:#0f172a;background:#fff;border-radius:50%;justify-content:center;align-items:center;width:45px;height:45px;font-size:1.2rem;transition:all .3s;display:flex;box-shadow:0 5px 15px #0000000d}.contact-page .contact-wrapper .contact-info .social-links .links a:hover{color:#fff;background:#2563eb;transform:translateY(-5px)}.contact-page .contact-wrapper .contact-form-container{background:#fff;border-radius:20px;flex:1.5;padding:40px;box-shadow:0 10px 30px #0000000d}.contact-page .contact-wrapper .contact-form-container .contact-form{flex-direction:column;gap:20px;display:flex}.contact-page .contact-wrapper .contact-form-container .contact-form .form-group input,.contact-page .contact-wrapper .contact-form-container .contact-form .form-group textarea{color:#0f172a;background:#fdfdfd;border:1px solid #eee;border-radius:10px;outline:none;width:100%;padding:15px;font-family:inherit;transition:border .3s}.contact-page .contact-wrapper .contact-form-container .contact-form .form-group input:focus,.contact-page .contact-wrapper .contact-form-container .contact-form .form-group textarea:focus{border-color:#2563eb}.contact-page .contact-wrapper .contact-form-container .contact-form .submit-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:10px;padding:15px;font-weight:600;transition:opacity .3s}.contact-page .contact-wrapper .contact-form-container .contact-form .submit-btn:hover{opacity:.9}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(400px,1fr));justify-content:center;gap:20px;width:100%;display:grid}@media (width<=768px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}}.project-details{background:#f8fafc;width:100%;min-height:100vh;padding:80px 0}.project-details .container{width:90%;max-width:1200px;margin:0 auto}.project-details .project-header{text-align:center;margin-bottom:40px}.project-details .project-header h1{color:#0f172a;margin-bottom:15px;font-size:3.5rem;font-weight:800}.project-details .project-header .tech-stack{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.project-details .project-header .tech-stack .tech-badge{color:#fff;background:#2563eb;border-radius:50px;padding:6px 18px;font-size:.85rem;font-weight:600;box-shadow:0 4px 10px #0000001a}.project-details .screenshots-container{margin:40px 0;position:relative}.project-details .screenshots-container .scroll-wrapper{scroll-snap-type:x mandatory;scrollbar-width:thin;scrollbar-color:#2563eb transparent;gap:20px;padding:20px 0;display:flex;overflow-x:auto}.project-details .screenshots-container .scroll-wrapper::-webkit-scrollbar{height:6px}.project-details .screenshots-container .scroll-wrapper::-webkit-scrollbar-thumb{background:#2563eb;border-radius:10px}.project-details .screenshots-container .scroll-wrapper .scroll-item{scroll-snap-align:center;border-radius:15px;flex:0 0 70%;overflow:hidden;box-shadow:0 10px 30px #00000026}@media (width<=768px){.project-details .screenshots-container .scroll-wrapper .scroll-item{flex:0 0 90%}}.project-details .screenshots-container .scroll-wrapper .scroll-item img{object-fit:cover;width:100%;height:auto;display:block}.project-details .description-section{background:#fff;border-radius:20px;margin-top:20px;padding:40px;box-shadow:0 5px 20px #0000000d}.project-details .description-section h2{color:#0f172a;border-left:5px solid #2563eb;margin-bottom:15px;padding-left:15px;font-size:1.8rem}.project-details .description-section p{color:#475569;font-size:1.1rem;line-height:1.8}.screenshots-container{align-items:center;margin:40px 0;display:flex;position:relative}.screenshots-container .nav-btn{z-index:10;color:#fff;cursor:pointer;background:#2563ebcc;border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%);box-shadow:0 4px 15px #0003}.screenshots-container .nav-btn:hover{background:#2563eb;scale:1.1}.screenshots-container .nav-btn.left{left:-25px}.screenshots-container .nav-btn.right{right:-25px}@media (width<=768px){.screenshots-container .nav-btn{width:40px;height:40px}.screenshots-container .nav-btn.left{left:0}.screenshots-container .nav-btn.right{right:0}}.screenshots-container .scroll-wrapper{scroll-behavior:smooth;scrollbar-width:none;gap:20px;padding:10px 0;display:flex;overflow-x:auto}.screenshots-container .scroll-wrapper::-webkit-scrollbar{display:none}.screenshots-container .scroll-wrapper .scroll-item{border-radius:15px;flex:0 0 80%;overflow:hidden}.screenshots-container .scroll-wrapper .scroll-item img{width:100%;display:block}.liveButtons{justify-content:center;gap:20px;display:flex}.liveButtons button{padding:10px}.admin-blogs{margin-top:0;padding:32px}.admin-blogs-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.admin-blogs-header .header-left{align-items:center;gap:12px;display:flex}.menu-toggle{cursor:pointer;background:0 0;border:0;border-radius:8px;padding:6px;display:none}.blogs-table table{border-collapse:collapse;width:100%;margin-top:0}.blogs-table th,.blogs-table td{text-align:left;border-bottom:1px solid #0f141e0a;padding:12px 14px}.actions button{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px}.actions button:hover{background:#0000000a}@media (width<=720px){.admin-blogs{padding:16px}.menu-toggle{display:inline-flex}.blogs-table th:nth-child(2),.blogs-table td:nth-child(2){display:none}}.sidebar-backdrop{z-index:30;background:#00000059;position:fixed;inset:0}.dashboard-container{background:var(--bg,#f9fafb);justify-content:center;align-items:flex-start;min-height:fit-content;max-height:fit-content;margin-top:70px;padding:20px;display:flex}.dashboard-container .admin-blogs,.dashboard-container .admin-blogs .blogs-table{justify-content:flex-start;align-items:flex-start;width:100%;display:flex}.blog{--blog-max-width:1200px;--card-radius:12px;--glass-bg:#fff9;--glass-border:#ffffff73;--muted:#6b7280;--primary:#0b76ff;--accent:#7c3aed;--text:#0f172a;padding:3rem 0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial}.blog-hero{text-align:center;margin-bottom:2rem}.blog-hero h1{letter-spacing:-.02em;color:var(--text);margin:0 0 .4rem;font-size:2.1rem;font-weight:700}.blog-hero p{color:var(--muted);margin:0;font-size:1rem}.blog-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));align-items:start;gap:1.4rem;max-width:1200px;margin:0 auto;padding:0 1rem;display:grid}.container{width:100%;max-width:var(--blog-max-width);margin:0 auto}@media (width>=768px){.blog{padding:4rem 0}}.blog-card{-webkit-backdrop-filter:blur(8px)saturate(120%);border-radius:var(--card-radius,12px);will-change:transform;opacity:0;background:linear-gradient(135deg,#ffffff9e,#f8fafc8f);border:1px solid #ffffff80;flex-direction:column;transition:transform .26s cubic-bezier(.2,.9,.2,1),box-shadow .26s;display:flex;overflow:hidden;transform:translateY(0);box-shadow:0 8px 30px #0c12280f}.blog-card.fade-up{animation:.52s cubic-bezier(.2,.9,.2,1) forwards fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.blog-card:hover{transform:translateY(-8px)scale(1.01);box-shadow:0 28px 60px #0c12281f}.blog-card .thumb{width:100%;height:180px;overflow:hidden}.blog-card img{object-fit:cover;width:100%;height:100%;transition:transform .42s;display:block}.blog-card:hover img{transform:scale(1.05)translateZ(0)}.card-body{text-align:left;flex-direction:column;flex:auto;gap:.6rem;padding:1.2rem 1.25rem;display:flex}.title{color:var(--text,#0f172a);margin:0;font-size:1.08rem;font-weight:700;line-height:1.25}.excerpt{color:#444;-webkit-line-clamp:3;text-overflow:ellipsis;-webkit-box-orient:vertical;flex:auto;margin:.35rem 0 .6rem;font-size:.96rem;display:-webkit-box;overflow:hidden}.meta{border-top:1px solid #0f141e0b;justify-content:flex-start;align-items:center;gap:1rem;margin-top:.9rem;padding-top:.9rem;font-size:.92rem;display:flex}.date{color:#6b7280;flex:auto;font-size:.9rem}.read-more{background:linear-gradient(90deg, var(--primary,#0b76ff), var(--accent,#7c3aed));color:#fff;white-space:nowrap;border:1px solid #ffffff1f;border-radius:10px;align-self:center;margin-left:1rem;padding:.52rem 1.05rem;font-weight:700;text-decoration:none;transition:transform .16s,box-shadow .16s,opacity .16s;box-shadow:0 12px 32px #0b76ff1a}.read-more:hover{transform:translateY(-4px)scale(1.02);box-shadow:0 28px 52px #0b76ff24}.read-more:focus-visible{outline-offset:2px;outline:3px solid #0b76ff24}.card-body .meta{margin-top:auto}@media (width<=520px){.meta{flex-direction:column;align-items:flex-start;gap:.6rem}.read-more{align-self:flex-end;margin-left:0}}.blog-details{padding:calc(var(--header-offset,72px) + 2.25rem) 0 4rem;color:var(--text,#0f172a)}.details-hero{text-align:left;background:linear-gradient(#ffffffb3,#fafafc99);border:1px solid #0f141e0a;border-radius:14px;max-width:920px;margin:0 auto 1.6rem;padding:1.1rem 1.2rem;box-shadow:0 8px 30px #080c180f}.details-title{letter-spacing:-.02em;color:var(--text,#0f172a);margin:0 0 .4rem;font-size:2.2rem;font-weight:800;line-height:1.04}.details-subtitle{color:var(--muted,#6b7280);margin:0 0 .6rem;font-size:1.02rem;font-weight:500}.details-meta{color:var(--muted,#6b7280);justify-content:space-between;align-items:center;margin-top:.6rem;font-size:.95rem;display:flex}.back-link{color:#fff;background:linear-gradient(90deg, var(--primary,#0b76ff), var(--accent,#7c3aed));border-radius:8px;padding:.45rem .85rem;font-weight:700;text-decoration:none;box-shadow:0 10px 26px #0b76ff1a}.details-body{grid-template-columns:1fr 380px;align-items:start;gap:2rem;max-width:1100px;margin:1.4rem auto 0;display:grid}.hero-image{border:1px solid #0f141e08;border-radius:12px;width:100%;height:420px;overflow:hidden;box-shadow:0 16px 40px #0a14280f}.hero-image img{object-fit:cover;width:100%;height:100%;display:block}.content{color:#222;max-width:720px;font-size:1.02rem;line-height:1.75}.content p:first-of-type:first-letter{float:left;color:var(--primary,#0b76ff);margin-right:.6rem;font-size:3.2rem;font-weight:700;line-height:1}@media (width<=880px){.blog-details{padding-top:calc(var(--header-offset,64px) + 1.25rem)}.details-body{grid-template-columns:1fr}.hero-image{height:260px}.details-hero{border-radius:10px;padding:.9rem}.details-title{font-size:1.6rem}}.fade-up{opacity:0;animation:.56s cubic-bezier(.2,.9,.2,1) forwards fadeUp;transform:translateY(12px)}
