@import "https://fonts.googleapis.com/css2?family=Fredoka:wght@300..700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#30011e;--surface:#3b0225;--surface2:#200114;--border:#30011e;--text:#dd9296;--muted:#6b7280;--steel:#8a9ba8;--amber:#f5a623;--amber-dim:#bbdef0;--danger:#e05252;--mono:"Fredoka", monospace;--sans:"Fredoka", sans-serif;--page-max:1100px;--header-h:56px}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.6}a{color:var(--text)}a:hover{color:var(--amber)}.hero-eyebrow{font-family:var(--mono);letter-spacing:.15em;text-transform:uppercase;color:var(--amber);margin-bottom:24px;font-size:14px}.header{z-index:100;height:var(--header-h);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0d0d0deb;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.header-inner{max-width:var(--page-max);justify-content:space-between;align-items:center;width:100%;margin:0 auto;padding:0 24px;display:flex}.logo{font-family:var(--mono);letter-spacing:.08em;color:var(--text);cursor:pointer;background:0 0;border:none;font-size:13px;font-weight:700;text-decoration:none}.logo span{color:var(--amber)}.nav{align-items:center;gap:28px;display:flex}.nav-link{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);cursor:pointer;background:0 0;border:none;font-size:11px;font-weight:500;text-decoration:none;transition:color .15s}.nav-link:hover,.nav-link.active{color:var(--text)}.nav-link.active{color:var(--amber)}.page{min-height:100vh;padding-top:var(--header-h)}.page-inner{max-width:var(--page-max);margin:0 auto;padding:0 24px}.project-grid{background:var(--border);gap:8px;display:grid}.project-grid-2{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.project-card{background:var(--bg);border:1px solid var(--bg);cursor:pointer;color:inherit;border-radius:8px;padding:28px;text-decoration:none;transition:all .15s;display:block}.project-card:hover{background:var(--surface);border:1px solid var(--amber)}.project-card:hover .card-title{color:var(--amber)}.card-top{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.card-title{font-family:var(--mono);color:var(--text);font-size:14px;font-weight:700;line-height:1.3}.card-year{font-family:var(--mono);color:var(--muted);letter-spacing:.08em;white-space:nowrap;margin-left:12px;font-size:10px}.card-desc{color:var(--steel);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:16px;font-size:13px;line-height:1.6;display:-webkit-box;overflow:hidden}.card-tags{flex-wrap:wrap;gap:6px;display:flex}.tag{font-family:var(--mono);letter-spacing:.08em;border:1px solid var(--border);color:var(--muted);text-transform:uppercase;border-radius:2px;padding:3px 8px;font-size:10px}.tag-status{border-color:var(--amber-dim);color:var(--amber)}.tag-status.complete{color:#5bc85b;border-color:#2a5c2a}.tag-status.archived{color:var(--muted);border-color:#333}.tag-status.in-progress{color:#e0b040;border-color:#3a3000}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:flex-end;align-items:flex-start;display:flex;position:fixed;inset:0;overflow-y:auto}.modal-panel{background:var(--surface);border-left:1px solid var(--border);width:100%;max-width:560px;min-height:100vh;padding:40px 36px;animation:.2s slideIn}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.modal-head{justify-content:space-between;align-items:flex-start;margin-bottom:32px;display:flex}.modal-title{font-family:var(--mono);color:var(--text);font-size:14px;font-weight:700}.modal-sub{font-family:var(--mono);color:var(--muted);margin-top:4px;font-size:11px}.modal-close{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;transition:all .12s;display:flex}.modal-close:hover{border-color:var(--text);color:var(--text)}.modal-footer{border-top:1px solid var(--border);gap:10px;margin-top:32px;padding-top:24px;display:flex}.tags-input-wrap{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.tag-removable{font-family:var(--mono);border:1px solid var(--border);color:var(--steel);align-items:center;gap:6px;padding:4px 8px;font-size:10px;display:flex}.tag-remove-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;line-height:1}.tag-remove-btn:hover{color:var(--danger)}.footer{border-top:1px solid var(--border);text-align:center;padding:32px 0}.footer-text{font-family:var(--mono);color:var(--muted);letter-spacing:.06em;font-size:11px}.footer-text span{color:var(--amber)}.about-hero{border-bottom:1px solid var(--border);grid-template-columns:1fr 320px;align-items:start;gap:60px;padding:100px 0 10px;display:grid}.about-name{font-family:var(--mono);color:var(--text);margin-bottom:16px;font-size:clamp(28px,4vw,48px);font-weight:700;line-height:1.1}.about-name span{color:var(--amber)}.about-body{color:var(--steel);font-size:15px;line-height:1.8}.aside-block{border:1px solid var(--border);margin-bottom:16px;padding:20px}.aside-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;font-size:10px}.aside-list{list-style:none}.aside-list li{font-family:var(--mono);color:var(--steel);border-bottom:1px solid var(--border);padding:4px 0;font-size:16px}.aside-list li:last-child{border-bottom:none}.about-section{border-bottom:1px solid var(--border);padding:30px 0 0}.about-section-title{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:32px;font-size:11px}.skills-grid{background:var(--border);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1px;display:grid}.skill-cell{background:var(--bg);font-family:var(--mono);color:var(--steel);padding:16px 20px;font-size:16px}.skill-cell strong{color:var(--text);margin-bottom:4px;font-size:18px;display:block}.tl-item{border-bottom:1px solid var(--border);grid-template-columns:80px 1fr;gap:24px;padding:24px 0;display:grid}.tl-year{font-family:var(--mono);color:var(--amber);padding-top:2px;font-size:11px}.tl-title{font-family:var(--mono);color:var(--text);margin-bottom:4px;font-size:13px;font-weight:700}.tl-org{color:var(--steel);margin-bottom:4px;font-size:12px}.tl-desc{color:var(--muted);font-size:13px}.gallery-hero{border-bottom:1px solid var(--border);padding:120px 0 10px}.gallery-title{font-family:var(--mono);color:var(--text);margin-bottom:8px;font-size:clamp(24px,4vw,42px);font-weight:700}.gallery-sub{color:var(--muted);font-size:14px}.gallery-filters{background-color:var(--surface2);border-bottom:0px solid var(--border);border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;padding:12px 24px;display:flex}.filter-btn{font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--border);cursor:pointer;color:var(--muted);background:0 0;border-radius:8px;padding:6px 14px;font-size:10px;transition:all .12s}.filter-btn:hover{border-color:var(--steel);color:var(--text)}.filter-btn.active{border-color:var(--amber);color:var(--amber);background:#f5a6230f}.gallery-list{padding:10px 0}.pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;padding:5px 0;display:flex}.page-btn{font-family:var(--mono);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--muted);background:0 0;justify-content:center;align-items:center;font-size:11px;transition:all .12s;display:flex}.page-btn:hover:not(:disabled){border-color:var(--steel);color:var(--text)}.page-btn.active{border-color:var(--amber);color:var(--amber)}.page-btn:disabled{opacity:.3;cursor:default}.hero{border-bottom:1px solid var(--border);padding:100px 0 30px;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background-image:repeating-linear-gradient(0deg,#0000,#0000 28px,#f8a42306 28px 29px);position:absolute;inset:0}.hero-title{font-family:var(--mono);letter-spacing:-.02em;color:var(--text);margin-bottom:24px;font-size:clamp(32px,5vw,58px);font-weight:700;line-height:1.1}.hero-title em{color:var(--amber);font-style:normal}.hero-sub{color:var(--steel);max-width:520px;margin-bottom:40px;font-size:16px;line-height:1.7}.hero-actions{flex-wrap:wrap;gap:12px;display:flex}.btn{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid;border-radius:8px;padding:10px 20px;font-size:11px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-block}.btn-primary{color:var(--bg);background:var(--amber);border-color:var(--amber)}.btn-primary:hover{background:#e09820;border-color:#e09820}.btn-outline{color:var(--text);border-color:var(--border)}.btn-outline:hover{border-color:var(--steel);color:var(--text)}.btn-ghost{color:var(--muted);border-color:#0000}.btn-ghost:hover{color:var(--text);border-color:var(--border)}.btn-danger{color:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:6px 14px;font-size:10px}.home-stats{border-top:1px solid var(--border);grid-template-columns:repeat(3,1fr);margin-top:30px;display:grid}.stat-cell{border-right:1px solid var(--border);padding:32px 0}.stat-cell:last-child{border-right:none}.stat-num{font-family:var(--mono);color:var(--text);font-size:36px;font-weight:700;line-height:1}.stat-label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:6px;font-size:10px}.home-featured{border-bottom:1px solid var(--border);padding:80px 0}.section-head{justify-content:space-between;align-items:baseline;margin-bottom:20px;display:flex}.section-title{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:500}.home-cta{text-align:center;padding:80px 0}.home-cta-title{font-family:var(--mono);color:var(--text);margin-bottom:16px;font-size:clamp(20px,3vw,32px);font-weight:700}.home-cta-sub{color:var(--muted);margin-bottom:32px}.login-wrap{min-height:calc(100vh - var(--header-h));justify-content:center;align-items:center;padding:40px 24px;display:flex}.login-box{border:1px solid var(--border);background:var(--surface);border-radius:8px;width:100%;max-width:380px;padding:40px}.login-title{font-family:var(--mono);color:var(--text);margin-bottom:8px;font-size:14px;font-weight:700}.login-sub{color:var(--muted);margin-bottom:28px;font-size:12px}.field{margin-bottom:16px}.field-label{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-size:10px;display:block}.field-input{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--mono);border-radius:8px;outline:none;padding:10px 12px;font-size:13px;transition:border-color .12s}.field-input:focus{border-color:var(--amber)}.field-input.error-input{border-color:var(--danger)}.field-input::placeholder{color:var(--muted)}.field-textarea{resize:vertical;min-height:100px}.error-msg{font-family:var(--mono);color:var(--danger);margin-top:10px;font-size:11px}.admin-wrap{padding:40px 0 80px}.admin-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;display:flex}.admin-title{font-family:var(--mono);color:var(--text);font-size:16px;font-weight:700}.admin-sub{font-family:var(--mono);color:var(--muted);margin-top:4px;font-size:11px}.admin-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.search-input-wrap{flex:1;min-width:200px;position:relative}.search-icon{color:var(--muted);pointer-events:none;font-size:12px;font-family:var(--mono);position:absolute;top:50%;left:10px;transform:translateY(-50%)}.search-input{background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--mono);border-radius:8px;outline:none;padding:8px 12px 8px 32px;font-size:12px;transition:border-color .12s}.search-input:focus{border-color:var(--steel)}.select-input{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:var(--mono);cursor:pointer;appearance:none;border-radius:8px;outline:none;min-width:130px;padding:8px 12px;font-size:11px}.admin-table{border-collapse:collapse;width:100%}.admin-table th{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:10px}.admin-table td{border-bottom:1px solid var(--border);vertical-align:top;padding:14px 16px;font-size:13px}.admin-table tr:hover td{background:var(--surface)}.table-title{font-family:var(--mono);color:var(--text);font-size:12px;font-weight:700}.table-desc{color:var(--muted);-webkit-line-clamp:1;-webkit-box-orient:vertical;max-width:320px;margin-top:3px;font-size:12px;display:-webkit-box;overflow:hidden}.table-actions{white-space:nowrap;gap:8px;display:flex}.empty-state{text-align:center;font-family:var(--mono);color:var(--muted);padding:80px 0;font-size:12px}@media (width<=680px){.about-hero,.home-stats{grid-template-columns:1fr}.stat-cell{border-right:none;border-bottom:1px solid var(--border)}.admin-table thead{display:none}.admin-table td{border-bottom:none;padding:8px 12px;display:block}.admin-table tr{border-bottom:1px solid var(--border);padding:8px 0;display:block}.project-grid-2{grid-template-columns:1fr}}
