:root{font-family:Manrope,Noto Sans SC,sans-serif;color:#112136;background:radial-gradient(circle at top left,rgba(17,119,255,.12),transparent 30%),linear-gradient(180deg,#fcfeff,#f5f9ff);text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--shell-width: min(1120px, calc(100vw - 48px) );--surface: rgba(255, 255, 255, .84);--border: rgba(145, 168, 197, .22);--border-strong: rgba(17, 119, 255, .18);--text: #112136;--muted: #61738b;--accent: #1177ff;--accent-deep: #0d56b8;--accent-soft: #eaf3ff;--success: #138f5f;--shadow: 0 28px 80px rgba(17, 57, 110, .11);--shadow-soft: 0 18px 40px rgba(17, 57, 110, .08)}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;min-width:320px;color:var(--text)}.loading-page{display:grid;place-items:center;min-height:100vh;padding:24px}.loading-card{width:min(520px,100%);padding:28px;border:1px solid rgba(180,199,225,.7);border-radius:20px;background:#ffffffe6;box-shadow:var(--shadow-soft);text-align:center}.loading-card h1{margin:0 0 10px;font-size:1.5rem}.loading-card p{margin:0 0 16px;color:var(--muted)}.loading-retry-btn{width:100%}a{color:inherit;text-decoration:none}button{font:inherit}img{display:block;max-width:100%}.shell{width:var(--shell-width);margin:0 auto}.site-header{position:sticky;top:0;z-index:20;border-bottom:1px solid rgba(210,223,239,.6);background:#ffffffb8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.nav-inner{display:flex;align-items:center;justify-content:space-between;min-height:72px;gap:16px}.brand{font-size:1.2rem;font-weight:800;font-style:italic;letter-spacing:.04em;color:var(--accent)}.nav-links{display:flex;gap:32px;font-size:.95rem;color:var(--muted)}.nav-links a{transition:color .16s ease}.nav-links a:hover{color:var(--accent)}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:0;border-radius:14px;color:var(--muted);background:transparent;cursor:pointer;transition:color .16s ease,background .16s ease,transform .16s ease}.icon-button:hover{color:var(--accent);background:#1177ff14;transform:translateY(-1px)}.header-back-btn{min-height:40px;padding:0 14px;border:1px solid rgba(17,119,255,.24);border-radius:12px;background:#1177ff14;color:var(--accent-deep);font-weight:700;cursor:pointer}.page-main{padding:56px 0 88px}.page-status,.page-error{margin:0 0 20px;padding:12px 16px;border-radius:14px;font-size:.9rem;font-weight:600}.page-status{border:1px solid rgba(17,119,255,.18);background:#1177ff14;color:var(--accent-deep)}.page-error{border:1px solid rgba(199,46,68,.2);background:#c72e4414;color:#8a1f33}.hero-section,.projects-section{margin-bottom:104px}.hero-intro{display:grid;grid-template-columns:180px 1fr;gap:44px;align-items:start}.avatar-shell{position:relative;width:180px;height:180px}.avatar-glow{position:absolute;top:10px;right:10px;bottom:10px;left:10px;border-radius:36px;background:linear-gradient(135deg,#1177ff73,#2fd1b638);filter:blur(28px);opacity:.45;transition:opacity .22s ease}.avatar-shell:hover .avatar-glow{opacity:.7}.avatar-frame{position:relative;overflow:hidden;width:100%;height:100%;border:5px solid rgba(255,255,255,.95);border-radius:36px;background:linear-gradient(180deg,#f8fbff,#eef5ff);box-shadow:var(--shadow)}.avatar-frame img{width:100%;height:100%}.hero-title-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:12px}.hero-title-row h1,.section-heading h2,.contact-card h2{margin:0;font-family:Noto Sans SC,sans-serif}.hero-title-row h1{font-size:clamp(2.4rem,5vw,4rem);line-height:1}.availability-badge{display:inline-flex;align-items:center;min-height:34px;padding:0 14px;border:1px solid rgba(19,143,95,.16);border-radius:999px;color:var(--success);background:#138f5f14;font-size:.75rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;animation:pulseGlow 2s infinite}.hero-subtitle{margin:0 0 28px;color:var(--muted);font-size:1.18rem;font-weight:600}.meta-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 18px;margin-bottom:32px}.meta-item{display:flex;gap:10px;align-items:center;color:var(--muted);font-size:.96rem}.meta-item svg,.section-title-with-icon svg,.contact-footer svg{color:var(--accent)}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}.primary-button,.primary-inline-button,.modal-confirm{display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:50px;padding:0 22px;border:0;border-radius:18px;background:linear-gradient(135deg,#12233b,#1d3960);color:#fff;font-weight:800;box-shadow:0 18px 36px #12233b2e;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.primary-button:hover,.primary-inline-button:hover,.modal-confirm:hover{transform:translateY(-2px);background:linear-gradient(135deg,var(--accent-deep),var(--accent));box-shadow:0 22px 40px #17f3}.social-list{display:flex;gap:10px}.social-button,.secondary-inline-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:0 18px;border:1px solid var(--border);border-radius:18px;background:#fffc;color:var(--muted);box-shadow:var(--shadow-soft);transition:transform .18s ease,border-color .18s ease,color .18s ease,background .18s ease}.social-button{width:50px;padding:0}.social-button:hover,.secondary-inline-button:hover{transform:translateY(-2px);color:var(--accent);border-color:var(--border-strong);background:#fff}.highlight-panel{margin-top:44px;padding:32px;border:1px solid rgba(208,223,242,.7);border-radius:36px;background:linear-gradient(180deg,#ffffffb8,#f4f9ffeb);box-shadow:var(--shadow-soft)}.eyebrow{margin:0 0 18px;color:#8191a8;font-size:.7rem;font-weight:900;letter-spacing:.24em;text-transform:uppercase}.highlight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 28px}.highlight-item{display:flex;gap:12px;margin:0;color:#4b5f79;line-height:1.8;font-weight:600}.highlight-item span{color:var(--accent);font-weight:800}.section-heading{display:flex;gap:24px;align-items:end;margin-bottom:40px}.section-heading h2{margin-bottom:8px;font-size:clamp(2rem,3vw,2.8rem)}.section-heading p{margin:0;color:var(--muted)}.section-line{flex:1;height:1px;background:linear-gradient(90deg,rgba(194,211,232,.8),transparent)}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:28px}.project-card{display:flex;flex-direction:column;overflow:hidden;border:1px solid rgba(210,223,239,.74);border-radius:32px;background:#ffffffd6;box-shadow:var(--shadow-soft);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}.project-card:hover{transform:translateY(-6px);border-color:#1177ff29;box-shadow:0 24px 56px #11396e1f}.project-cover{position:relative;aspect-ratio:16 / 10;overflow:hidden;background:#eaf1fb}.project-cover img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.project-card:hover .project-cover img{transform:scale(1.05)}.project-period{position:absolute;top:16px;right:16px;padding:6px 10px;border-radius:12px;background:#ffffffe0;color:var(--muted);font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.project-body{display:flex;flex:1;flex-direction:column;padding:24px}.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.tag{padding:6px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:.7rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.project-body h3{margin:0 0 12px;font-size:1.35rem;line-height:1.35}.project-description{margin:0 0 22px;color:var(--muted);line-height:1.8;font-style:italic;flex:1}.project-role{flex:1;margin-bottom:22px;padding:16px;border:1px solid rgba(210,223,239,.7);border-radius:24px;background:linear-gradient(180deg,#f8fbffeb,#f2f7ffeb)}.role-title{display:inline-flex;gap:8px;align-items:center;margin-bottom:10px;color:#7a8aa0;font-size:.72rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase}.project-role p{margin:0;line-height:1.8;color:#34485f;font-weight:600}.project-actions{display:flex;gap:12px;padding-top:20px;border-top:1px solid rgba(232,239,247,.9)}.primary-inline-button,.secondary-inline-button{flex:1;min-height:46px;padding:0 16px;font-size:.86rem}.bottom-layout{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,.9fr);gap:44px;padding-top:56px;border-top:1px solid rgba(210,223,239,.7)}.section-title-with-icon{display:flex;gap:12px;align-items:center;margin:0 0 28px;font-family:Noto Sans SC,sans-serif;font-size:1.8rem}.skills-groups{display:flex;flex-direction:column;gap:28px}.skill-chip-list{display:flex;flex-wrap:wrap;gap:12px}.skill-chip{padding:14px 18px;border:1px solid rgba(210,223,239,.74);border-radius:22px;background:#ffffffdb;color:#4a607c;font-weight:700;box-shadow:var(--shadow-soft);transition:transform .18s ease,border-color .18s ease,color .18s ease}.skill-chip:hover{transform:translateY(-2px);color:var(--accent);border-color:var(--border-strong)}.contact-card{position:sticky;top:102px;overflow:hidden;padding:34px;border-radius:40px;background:linear-gradient(160deg,#0d60d6,#0a7cf8 58%,#27c8cc 118%);color:#fff;box-shadow:0 28px 70px #1177ff4d}.contact-orb{position:absolute;top:-36px;right:-20px;width:170px;height:170px;border-radius:999px;background:#ffffff24;filter:blur(20px)}.contact-quote{position:relative;margin:14px 0 30px;color:#ffffffd6;font-style:italic;line-height:1.8}.contact-list{display:flex;flex-direction:column;gap:14px}.contact-link,.contact-static{display:flex;gap:14px;align-items:center;padding:16px;border:1px solid rgba(255,255,255,.16);border-radius:24px;background:#ffffff14}.contact-link:hover{background:#ffffff24}.contact-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:16px;background:#ffffff24}.contact-link span,.contact-static span{display:flex;flex-direction:column;gap:6px}.contact-link small,.contact-static small{color:#d6ebffd6;font-size:.68rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase}.contact-footer{display:inline-flex;gap:8px;align-items:center;margin:30px 0 0;color:#d6ebffd6;font-size:.75rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase}.site-footer{padding:28px 0 40px;border-top:1px solid rgba(225,235,246,.9);text-align:center}.site-footer p{margin:0;color:#9aabc0;font-size:.72rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:grid;place-items:center;padding:24px;background:#0e182a8c;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.modal-card{width:min(520px,100%);padding:28px;border:1px solid rgba(210,223,239,.8);border-radius:32px;background:#fff;box-shadow:var(--shadow)}.modal-card-wide{width:min(900px,100%)}.modal-header{display:flex;gap:16px;align-items:center;justify-content:space-between;margin-bottom:18px}.modal-header h3{margin:0;font-size:1.4rem}.modal-description{margin:0 0 20px;color:var(--muted);line-height:1.8}.sql-hint{margin-bottom:20px;padding:16px;border:1px solid rgba(17,119,255,.12);border-radius:18px;background:#1177ff14;color:var(--accent-deep);font-size:.92rem;font-weight:600}.modal-confirm{width:100%}.admin-login-panel,.admin-editor{display:flex;flex-direction:column;gap:14px}.admin-modal-shell{max-height:min(92vh,980px);overflow:auto}.admin-page{min-height:calc(100vh - 72px);padding:28px 0 44px}.admin-page-layout{display:grid;grid-template-columns:280px 1fr;gap:18px}.admin-sidebar{position:sticky;top:94px;height:fit-content;padding:18px;border:1px solid rgba(180,199,225,.7);border-radius:18px;background:linear-gradient(180deg,#fff,#f5f9ff);box-shadow:var(--shadow-soft)}.admin-sidebar h3{margin:0 0 8px}.admin-sidebar p{margin:0 0 14px;color:var(--muted);line-height:1.6}.admin-bucket-tip{margin:0 0 14px;padding:10px 12px;border:1px solid rgba(17,119,255,.18);border-radius:10px;background:#1177ff14;color:#35517a;font-size:.84rem}.admin-content{padding:18px;border:1px solid rgba(180,199,225,.7);border-radius:18px;background:#ffffffdb;box-shadow:var(--shadow-soft)}.admin-save-bar{position:sticky;bottom:0;padding-top:12px;background:linear-gradient(180deg,#fff0,#fff 40%)}.admin-save-btn{width:100%}.admin-login-layout{display:grid;place-items:center;min-height:calc(100vh - 140px)}.admin-login-card{width:min(520px,100%);padding:22px;border:1px solid rgba(180,199,225,.7);border-radius:18px;background:#ffffffe6;box-shadow:var(--shadow-soft)}.admin-login-card h2{margin:0 0 8px}.admin-login-card p{margin:0 0 14px;color:var(--muted)}.admin-editor-toolbar{display:flex;gap:12px}.admin-login-panel label,.admin-editor label{display:flex;flex-direction:column;gap:8px;color:#3f5471;font-size:.86rem;font-weight:700}.admin-input,.admin-textarea{width:100%;padding:11px 12px;border:1px solid rgba(180,199,225,.8);border-radius:12px;background:#fff;color:var(--text)}.admin-textarea{min-height:140px;resize:vertical;font-family:Courier New,monospace;line-height:1.55}.admin-textarea.short{min-height:90px}.admin-grid{display:flex;flex-direction:column;gap:14px}.admin-section{padding:14px;border:1px solid rgba(180,199,225,.7);border-radius:14px;background:linear-gradient(180deg,#fff,#f8fbff)}.admin-section h4{margin:0 0 12px;color:#2d4669;font-size:1rem}.admin-section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.admin-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.admin-row-card{margin-top:10px;padding:12px;border:1px solid rgba(190,205,227,.7);border-radius:12px;background:#fff}.admin-upload-row{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 10px}.admin-upload-trigger{position:relative;display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:0 12px;border-radius:10px;border:1px solid rgba(17,119,255,.24);background:#1177ff14;color:#1f5cae;font-size:.82rem;font-weight:700;cursor:pointer}.admin-upload-trigger input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer}.admin-mini-btn,.admin-danger-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:36px;padding:0 12px;border-radius:10px;border:1px solid rgba(180,199,225,.8);background:#fff;color:#466288;cursor:pointer}.admin-mini-btn:hover{color:var(--accent);border-color:#1177ff4d}.admin-danger-btn{margin-top:10px;color:#a9314f;border-color:#d85e7c59}.admin-danger-btn:hover{background:#d85e7c14}.admin-error,.admin-status{margin:12px 0 0;padding:10px 12px;border-radius:12px;font-size:.86rem;font-weight:600}.admin-error{border:1px solid rgba(199,46,68,.2);background:#c72e4414;color:#8a1f33}.admin-status{border:1px solid rgba(17,119,255,.18);background:#1177ff14;color:var(--accent-deep)}.spin{animation:spin 1s linear infinite}@keyframes pulseGlow{0%,to{box-shadow:0 0 #138f5f33}50%{box-shadow:0 0 0 12px #138f5f00}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1100px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.bottom-layout{grid-template-columns:1fr}.contact-card{position:relative;top:auto}.admin-page-layout{grid-template-columns:1fr}.admin-sidebar{position:relative;top:auto}}@media (max-width: 820px){.nav-links,.section-line{display:none}.page-main{padding-top:36px}.hero-section,.projects-section{margin-bottom:76px}.hero-intro,.highlight-grid,.meta-grid,.project-grid{grid-template-columns:1fr}.avatar-shell{width:132px;height:132px}}@media (max-width: 560px){:root{--shell-width: min(1120px, calc(100vw - 28px) )}.nav-inner{min-height:64px}.highlight-panel,.project-body,.contact-card,.modal-card{padding:22px}.hero-actions,.project-actions{flex-direction:column}.primary-button,.primary-inline-button,.secondary-inline-button,.modal-confirm{width:100%}.admin-editor-toolbar{flex-direction:column}.admin-two-col{grid-template-columns:1fr}}
