@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Sarabun:wght@200;300;400;500;600;700;800&display=swap";:root{--bg-primary:#0a0e17;--bg-secondary:#121824;--bg-tertiary:#1b2336;--color-cyan:#00e5ff;--color-blue:#06f;--color-purple:#9d4edd;--text-primary:#fff;--text-secondary:#94a3b8;--text-muted:#64748b;--border-color:#00e5ff26;--border-glow:#00e5ff66;--font-en:"Outfit", sans-serif;--font-th:"Sarabun", sans-serif;--transition:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);font-family:var(--font-th), var(--font-en);line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-cyan)}.app-container{flex-direction:column;min-height:100vh;display:flex}.navbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;background:#0a0e17d9;border-bottom:1px solid #00e5ff14;justify-content:space-between;align-items:center;width:100%;padding:1.25rem 2rem;display:flex;position:fixed;top:0;left:0}.nav-logo{font-family:var(--font-en);color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.5rem;font-weight:800;text-decoration:none;display:flex}.logo-glow{color:var(--color-cyan);text-shadow:0 0 10px #00e5ff80}.nav-links{gap:1.5rem;display:flex}.nav-link{color:var(--text-secondary);transition:var(--transition);border-radius:8px;padding:.5rem 1rem;font-size:.95rem;font-weight:500;text-decoration:none}.nav-link:hover,.nav-link.active{color:var(--color-cyan);background:#00e5ff0f}.local-banner{color:#fff;text-align:center;letter-spacing:.5px;z-index:999;background:linear-gradient(90deg,#001f3f,#05f);padding:.5rem;font-size:.85rem;font-weight:600;position:sticky;top:73px}section{width:100%;max-width:1200px;margin:0 auto;padding:6rem 2rem 4rem}.section-title{font-family:var(--font-en);text-align:center;letter-spacing:1px;margin-bottom:3.5rem;font-size:2.2rem;font-weight:700;position:relative}.section-title:after{content:"";background:linear-gradient(90deg, var(--color-blue), var(--color-cyan));border-radius:2px;width:60px;height:3px;position:absolute;bottom:-10px;left:50%;transform:translate(-50%);box-shadow:0 0 10px #00e5ff80}.hero-wrapper{grid-template-columns:350px 1fr;align-items:center;gap:4rem;margin-top:2rem;display:grid}.hero-img-container{aspect-ratio:1;border:2px solid var(--border-color);transition:var(--transition);border-radius:24px;position:relative;overflow:hidden;box-shadow:0 0 30px #0055ff26}.hero-img-container:before{content:"";border:1px solid var(--color-cyan);opacity:.5;pointer-events:none;border-radius:22px;position:absolute;inset:0}.hero-img-container:hover{border-color:var(--color-cyan);transform:scale(1.02);box-shadow:0 0 30px #00e5ff4d}.hero-img{object-fit:cover;width:100%;height:100%}.hero-content{position:relative}.hero-name{background:linear-gradient(135deg, #fff 30%, var(--color-cyan) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.5rem;font-size:2.5rem;font-weight:800}.hero-subtitle{font-family:var(--font-en);color:var(--color-cyan);letter-spacing:.5px;margin-bottom:2rem;font-size:1.25rem;font-weight:500}.hero-bio-quote{color:var(--text-secondary);border-left:4px solid var(--color-blue);background:#12182480;border-top:1px solid #00e5ff0d;border-bottom:1px solid #00e5ff0d;border-right:1px solid #00e5ff0d;border-radius:0 16px 16px 0;padding:1.5rem 2.5rem;font-size:1.1rem;position:relative}.hero-bio-quote:before{content:"“";color:var(--color-cyan);opacity:.25;font-family:serif;font-size:4rem;line-height:1;position:absolute;top:-5px;left:10px}.hero-bio-quote:after{content:"”";color:var(--color-cyan);opacity:.25;font-family:serif;font-size:4rem;line-height:1;position:absolute;bottom:-35px;right:15px}.category-block{margin-bottom:4rem}.category-title{color:var(--color-cyan);border-bottom:1px dashed #00e5ff26;align-items:center;gap:.75rem;margin-bottom:2rem;padding-bottom:.75rem;font-size:1.4rem;font-weight:600;display:flex}.portfolio-grid{grid-template-columns:repeat(4,1fr);gap:1.5rem;display:grid}.portfolio-card{background:var(--bg-secondary);transition:var(--transition);border:1px solid #00e5ff0f;border-radius:16px;flex-direction:column;height:100%;display:flex;overflow:hidden}.portfolio-card:hover{border-color:var(--color-cyan);transform:translateY(-8px);box-shadow:0 10px 25px #00e5ff14}.card-img-wrapper{aspect-ratio:4/3;background:var(--bg-tertiary);border-bottom:1px solid #00e5ff0d;position:relative;overflow:hidden}.card-img{object-fit:cover;width:100%;height:100%;transition:var(--transition)}.portfolio-card:hover .card-img{transform:scale(1.05)}.card-body{flex-direction:column;flex-grow:1;padding:1.25rem;display:flex}.card-title{color:var(--text-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:.75rem;font-size:1.05rem;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.card-desc{color:var(--text-secondary);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-top:auto;font-size:.88rem;line-height:1.5;display:-webkit-box;overflow:hidden}.empty-state{text-align:center;background:var(--bg-secondary);color:var(--text-secondary);border:1px dashed #00e5ff1a;border-radius:16px;grid-column:1/-1;padding:3rem}.carousel-section{border-y:1px solid #00e5ff0d;background:#12182466;width:100vw;margin-left:-50vw;margin-right:-50vw;padding:4rem 0;position:relative;left:50%;right:50%;overflow:hidden}.carousel-title{font-family:var(--font-en);text-align:center;color:var(--text-secondary);letter-spacing:.5px;margin-bottom:2.5rem;font-size:1.5rem}.carousel-container{width:100%;display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 15% 85%,#0000);mask-image:linear-gradient(90deg,#0000,#000 15% 85%,#0000)}.carousel-track{white-space:nowrap;gap:1.5rem;animation:40s linear infinite scroll;display:flex}.carousel-track:hover{animation-play-state:paused}.carousel-img-card{width:280px;height:190px;transition:var(--transition);border:1px solid #00e5ff1a;border-radius:12px;flex-shrink:0;overflow:hidden;box-shadow:0 5px 15px #0000004d}.carousel-img-card:hover{border-color:var(--color-cyan);transform:scale(1.03);box-shadow:0 0 20px #00e5ff33}.carousel-img{object-fit:cover;width:100%;height:100%}@keyframes scroll{0%{transform:translate(0)}to{transform:translate(calc(-1120px - 6rem))}}.footer{background-color:var(--bg-secondary);border-top:1px solid #00e5ff1a;margin-top:auto;padding:4rem 2rem 2rem}.footer-content{grid-template-columns:1fr 2fr;align-items:center;gap:4rem;max-width:1200px;margin:0 auto;display:grid}.footer-brand{flex-direction:column;gap:1rem;display:flex}.footer-logo{font-family:var(--font-en);color:var(--text-primary);font-size:1.8rem;font-weight:800;text-decoration:none}.footer-desc{color:var(--text-secondary);font-size:.9rem}.contact-grid{flex-direction:column;gap:1.5rem;display:flex}.contact-card{transition:var(--transition);align-items:center;gap:1.25rem;display:flex}.contact-logo-wrapper{background:var(--bg-tertiary);width:56px;height:56px;color:var(--color-cyan);transition:var(--transition);border:1px solid #00e5ff1a;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 10px #00000026}.contact-card:hover .contact-logo-wrapper{background:var(--color-cyan);color:var(--bg-primary);transform:rotate(10deg);box-shadow:0 0 15px #00e5ff66}.contact-details{flex-direction:column;display:flex}.contact-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;font-size:.8rem}.contact-val{color:var(--text-primary);font-size:1.05rem;font-weight:500}.footer-bottom{text-align:center;max-width:1200px;color:var(--text-muted);border-top:1px solid #00e5ff0d;margin:3rem auto 0;padding-top:1.5rem;font-size:.85rem}.admin-container{width:100%;max-width:1100px;margin:0 auto;padding-top:6rem}.admin-grid{grid-template-columns:280px 1fr;gap:2.5rem;margin-top:2rem;display:grid}.admin-sidebar{background:var(--bg-secondary);border:1px solid #00e5ff0f;border-radius:16px;flex-direction:column;gap:.75rem;height:fit-content;padding:1.5rem;display:flex}.admin-menu-item{text-align:left;width:100%;color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:10px;align-items:center;gap:.75rem;padding:.85rem 1.25rem;font-family:inherit;font-size:.95rem;font-weight:500;display:flex}.admin-menu-item:hover,.admin-menu-item.active{color:var(--color-cyan);background:#00e5ff0f}.admin-content{background:var(--bg-secondary);border:1px solid #00e5ff0f;border-radius:16px;padding:2rem}.admin-section-header{border-bottom:1px solid #00e5ff14;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.9rem;font-weight:600;display:block}.form-control{background:var(--bg-tertiary);color:#fff;width:100%;transition:var(--transition);border:1px solid #00e5ff1a;border-radius:8px;padding:.85rem;font-family:inherit;font-size:.95rem}.form-control:focus{border-color:var(--color-cyan);outline:none;box-shadow:0 0 10px #00e5ff26}textarea.form-control{resize:vertical;min-height:120px}.image-upload-wrapper{align-items:center;gap:1.5rem;display:flex}.image-preview-box{background:var(--bg-tertiary);border:1px solid #00e5ff26;border-radius:12px;flex-shrink:0;width:100px;height:100px;overflow:hidden}.image-preview-box img{object-fit:cover;width:100%;height:100%}.btn{cursor:pointer;transition:var(--transition);border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-family:inherit;font-size:.95rem;font-weight:600;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--color-blue), var(--color-cyan));color:var(--bg-primary);box-shadow:0 4px 15px #00e5ff33}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 20px #00e5ff66}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid #00e5ff1a}.btn-secondary:hover{border-color:var(--color-cyan);background:#00e5ff0d}.btn-danger{background:rgba(ef, 68, 68, .1);color:#ef4444;border:1px solid #ef444433}.btn-danger:hover{color:#fff;background:#ef4444}.admin-list{flex-direction:column;gap:1rem;display:flex}.admin-list-item{background:var(--bg-tertiary);transition:var(--transition);border:1px solid #00e5ff0d;border-radius:12px;justify-content:space-between;align-items:center;padding:1rem;display:flex}.admin-list-item:hover{border-color:#00e5ff26}.admin-item-info{align-items:center;gap:1rem;display:flex}.admin-item-thumb{object-fit:cover;background:var(--bg-secondary);border-radius:8px;width:50px;height:50px}.admin-item-meta h4{color:var(--text-primary);font-size:.98rem;font-weight:600}.admin-item-meta p{color:var(--text-secondary);margin-top:.1rem;font-size:.82rem}.admin-item-actions{gap:.5rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1100;background:#0a0e17cc;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;width:100%;max-width:600px;max-height:90vh;animation:.3s cubic-bezier(.34,1.56,.64,1) modalScale;overflow-y:auto;box-shadow:0 20px 40px #00e5ff1a}@keyframes modalScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid #00e5ff14;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid #00e5ff14;justify-content:flex-end;gap:.75rem;padding:1.25rem 1.5rem;display:flex}.toast{background:var(--bg-secondary);border-left:4px solid var(--color-cyan);color:#fff;z-index:2000;border-top:1px solid #00e5ff1a;border-bottom:1px solid #00e5ff1a;border-right:1px solid #00e5ff1a;border-radius:4px 12px 12px 4px;align-items:center;gap:.75rem;padding:1rem 1.5rem;animation:.3s cubic-bezier(.16,1,.3,1) slideIn;display:flex;position:fixed;bottom:2rem;right:2rem;box-shadow:0 10px 25px #0006}@keyframes slideIn{0%{opacity:0;transform:translateY(100px)}to{opacity:1;transform:translateY(0)}}.pdf-thumbnail-fallback{text-align:center;width:100%;height:100%;transition:var(--transition);background:linear-gradient(135deg,#1b2336 0%,#0d121f 100%);border:1px dashed #00e5ff40;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:.6rem;padding:1.5rem;display:flex;position:relative}.pdf-thumbnail-icon{color:#f87171;filter:drop-shadow(0 0 10px #f8717166)}.pdf-badge{color:#f87171;letter-spacing:.5px;background:#f8717126;border:1px solid #f871714d;border-radius:4px;padding:.2rem .5rem;font-size:.68rem;font-weight:800}.pdf-click-tip{color:var(--text-muted);font-size:.72rem}.portfolio-card:hover .pdf-thumbnail-fallback{border-color:var(--color-cyan);background:linear-gradient(135deg,#1e293b 0%,#172554 100%)}.pdf-link-btn{color:#f87171;width:fit-content;transition:var(--transition);background:#f871711a;border:1px solid #f8717133;border-radius:6px;align-items:center;gap:.35rem;margin-top:.75rem;padding:.35rem .75rem;font-size:.78rem;font-weight:600;display:inline-flex}.portfolio-card:hover .pdf-link-btn{color:#fff;background:#f87171;box-shadow:0 0 10px #f8717166}.admin-item-thumb-pdf{color:#f87171;background:#f871711a;border:1px solid #f8717133;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}@media (width<=1024px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}.hero-wrapper{gap:3rem}}@media (width<=768px){.navbar{flex-direction:row;justify-content:space-between;align-items:center;padding:.6rem 1rem}.nav-logo{font-size:1.1rem}.nav-links{gap:.15rem}.nav-link{padding:.25rem .4rem;font-size:.76rem}section{padding:5rem 1.5rem 3rem}.hero-wrapper{text-align:center;grid-template-columns:1fr;gap:2rem}.hero-img-container{max-width:260px;margin:0 auto}.hero-bio-quote{border-left:none;border-top:4px solid var(--color-blue);border-radius:0 0 16px 16px;padding:1.5rem}.portfolio-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.footer-content{text-align:center;grid-template-columns:1fr;gap:2.5rem}.contact-card{text-align:center;flex-direction:column;gap:.5rem}.admin-grid{grid-template-columns:1fr}.admin-sidebar{flex-direction:row;padding:.75rem;overflow-x:auto}.admin-menu-item{white-space:nowrap;width:auto}}@media (width<=480px){.hero-name{font-size:2rem}.portfolio-grid{grid-template-columns:1fr}.section-title{font-size:1.8rem}.image-upload-wrapper{flex-direction:column;align-items:flex-start}}
