:root{--highlight1:#034078;--highlight2:#034078;--highlight1-hover:#22d9e5;--highlight2-hover:#81e1eb;--background:#fff;--site-background:#f9fafb;--text:#1f2937;--text-muted:#4b5563;--nav-bg:#ffffffd9;--navtext:#1f2937;--card-bg:#fff;--card-border:#e5e7eb;--btn-bg:var(--highlight1);--btn-hover:var(--highlight1-hover);--btn-text:#fff;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 4px 6px -1px #0000001a,0 2px 4px -2px #0000001a;--shadow-hover:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--icon-filter:none}@media (prefers-color-scheme:dark){:root{--highlight1:#44aedb;--highlight2:#2191fb;--highlight1-hover:#22d9e5;--highlight2-hover:#0171db;--background:#111827;--site-background:#030712;--text:#f9fafb;--text-muted:#9ca3af;--nav-bg:#111827d9;--navtext:var(--text);--card-bg:#1f2937;--card-border:#374151;--btn-bg:var(--highlight2);--btn-hover:var(--highlight2-hover);--btn-text:#fff;--shadow-sm:0 1px 2px 0 #0000004d;--shadow:0 4px 6px -1px #0006,0 2px 4px -2px #0006;--shadow-hover:0 10px 15px -3px #00000080,0 4px 6px -4px #00000080;--icon-filter:invert(.8)sepia(1)hue-rotate(180deg)saturate(300%)brightness(.9)}}html{box-sizing:border-box;scroll-behavior:smooth;margin:0;padding:0;font-family:-apple-system,system-ui,sans-serif}*,:before,:after{box-sizing:inherit;margin:0;padding:0}body{background-color:var(--site-background);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;line-height:1.5}a{color:var(--highlight1);font-weight:600;text-decoration:none;transition:color .2s}a:hover{color:var(--highlight1-hover)}.app-container{padding-bottom:0}.header-nav{z-index:50;background-color:var(--nav-bg);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--card-border);justify-content:space-between;align-items:center;height:4rem;padding:0 2rem;display:flex;position:sticky;top:0}.header-title{color:var(--highlight1);letter-spacing:-.025em;margin:0;font-size:2rem;font-weight:700}.header-links-desktop{align-items:center;gap:2rem;display:flex}.header-links-desktop a{color:var(--navtext);font-size:1.125rem;font-weight:600}.header-links-desktop a:hover{color:var(--highlight1)}@media only screen and (max-width:900px){.header-links-desktop{display:none}}.header-mobile-toggle{cursor:pointer;color:var(--navtext);z-index:60;background:0 0;border:none;padding:.5rem;display:none}.header-mobile-toggle svg{width:1.75rem;height:1.75rem}@media only screen and (max-width:900px){.header-mobile-toggle{display:block}}.header-links-mobile{background-color:var(--background);z-index:40;border-top:1px solid var(--card-border);flex-direction:column;width:100vw;animation:.3s ease-out forwards slideIn;display:flex;position:fixed;top:4rem;bottom:0;right:0}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.header-links-mobile a{border-bottom:1px solid var(--card-border);text-align:center;color:var(--text);padding:1.5rem;font-size:1.5rem}.header-links-mobile a:hover{background-color:var(--site-background);color:var(--highlight1)}.main-content{flex-direction:column;gap:3rem;max-width:1200px;margin:0 auto;padding:2rem;display:flex}@media only screen and (max-width:900px){.main-content{gap:2rem;padding:1.5rem 1rem}}.category-section{flex-direction:column;display:flex}.category-anchor{position:relative;top:-5rem}.category-title{color:var(--text);border-bottom:2px solid var(--card-border);margin-bottom:1.5rem;padding-bottom:.5rem;font-size:1.875rem;font-weight:700}.category-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.service-card{background-color:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--shadow);border-radius:.75rem;flex-direction:column;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex;position:relative}.service-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-2px)}.service-card-header{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.service-icon{object-fit:contain;width:2.5rem;height:2.5rem;filter:var(--icon-filter);border-radius:.375rem}.service-title{color:var(--text);font-size:1.25rem;font-weight:700;line-height:1.2}.service-description{color:var(--text-muted);flex-grow:1;margin-bottom:1.5rem;font-size:1rem;line-height:1.5}.service-footer{border-top:1px solid var(--card-border);justify-content:flex-end;align-items:center;margin-top:auto;padding-top:1rem;display:flex}.service-github{color:var(--text-muted);align-items:center;gap:.375rem;margin-right:auto;font-size:.875rem;font-weight:600;display:flex}.service-github:hover{color:var(--highlight1)}.service-github svg{fill:currentColor;width:1.25rem;height:1.25rem}.service-open-btn{background-color:var(--btn-bg);color:var(--btn-text);border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:background-color .2s,transform .1s;display:inline-flex}.service-open-btn:hover{background-color:var(--btn-hover);color:var(--btn-text);text-decoration:none}.service-open-btn:active{transform:scale(.97)}.error-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;max-width:600px;min-height:70vh;margin:0 auto;padding:2rem;display:flex}.error-icon{color:#ef4444;width:5rem;height:5rem;margin-bottom:1.5rem}.error-title{color:var(--text);margin-bottom:1rem;font-size:2rem;font-weight:700}.error-message{color:var(--text-muted);margin-bottom:2rem;font-size:1.125rem;line-height:1.6}.error-actions{gap:1rem;display:flex}.btn-primary{background-color:var(--btn-bg);color:var(--btn-text);cursor:pointer;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-weight:600;transition:background-color .2s}.btn-primary:hover{background-color:var(--btn-hover);color:var(--btn-text)}.loading-container{flex-direction:column;justify-content:center;align-items:center;min-height:70vh;display:flex}.loading-spinner{border:4px solid var(--card-border);border-top-color:var(--highlight1);border-radius:50%;width:3rem;height:3rem;margin-bottom:1.5rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{color:var(--text-muted);font-size:1.25rem;font-weight:600}.empty-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:50vh;margin-top:2rem;padding:3rem;display:flex}.empty-title{color:var(--text);letter-spacing:-.025em;margin-bottom:1rem;font-size:2.25rem;font-weight:800}.empty-message{color:var(--text-muted);max-width:500px;font-size:1.25rem;line-height:1.6}.empty-help{background-color:var(--card-bg);border:1px solid var(--card-border);text-align:left;max-width:400px;box-shadow:var(--shadow-sm);border-radius:1rem;margin-top:2rem;padding:1.5rem}.empty-help-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.75rem;font-size:.875rem;font-weight:700;display:block}.empty-help-list{color:var(--highlight1);flex-direction:column;gap:.25rem;font-family:monospace;font-size:.875rem;list-style:none;display:flex}.admin-page{min-height:100vh}.admin-content{flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto;padding:1.5rem 2rem 5rem;display:flex}@media only screen and (max-width:900px){.admin-content{gap:1.5rem;padding:1rem 1rem 4rem}}.admin-nav-badge{background:var(--highlight1);color:#fff;letter-spacing:.05em;text-transform:uppercase;border-radius:999px;align-items:center;margin-left:.5rem;padding:.2rem .6rem;font-size:.75rem;font-weight:700;display:inline-flex}.admin-nav-back{color:var(--text-muted);margin-left:auto;font-size:.9rem;font-weight:600;transition:color .2s}.admin-nav-back:hover{color:var(--highlight1)}.admin-section{flex-direction:column;gap:1rem;display:flex}.admin-toolbar{align-items:center;gap:.75rem;display:flex}.admin-toolbar-title{color:var(--text);margin:0;font-size:1.875rem;font-weight:700}.admin-toolbar-count{background:linear-gradient(135deg,var(--highlight1),var(--highlight2));color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:1.625rem;height:1.625rem;margin-right:auto;padding:0 .45rem;font-size:.75rem;font-weight:700;line-height:1;display:inline-flex}.admin-form{flex-direction:column;gap:1.25rem;display:flex}.admin-form-actions{justify-content:flex-end;display:flex}.admin-form-group{flex-direction:column;gap:.5rem;display:flex}.admin-form-group--wide{grid-column:1/-1}.admin-label{color:var(--text);letter-spacing:.01em;font-size:.875rem;font-weight:600}.admin-input{background:var(--card-bg);border:1px solid var(--card-border);color:var(--text);border-radius:.625rem;outline:none;width:100%;padding:.625rem .875rem;font-family:inherit;font-size:1rem;transition:border-color .2s,box-shadow .2s}.admin-textarea{resize:vertical;min-height:8rem}.admin-select{appearance:none}.admin-input:focus{border-color:var(--highlight1);box-shadow:0 0 0 3px #03407826}@media (prefers-color-scheme:dark){.admin-input:focus{box-shadow:0 0 0 3px #44aedb33}}.admin-hint{color:var(--text-muted);font-size:.8125rem;line-height:1.4}.admin-hint code{color:var(--highlight1);font-family:monospace;font-size:.875em}.admin-file-input{display:none}.admin-file-label{cursor:pointer;flex-wrap:wrap;align-items:center;gap:.75rem;display:inline-flex}.admin-file-btn{background:var(--card-bg);border:1px solid var(--card-border);color:var(--highlight1);border-radius:.5rem;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:background .2s,border-color .2s;display:inline-flex}.admin-file-label:hover .admin-file-btn{background:var(--site-background);border-color:var(--highlight1)}.admin-file-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:28ch;font-size:.875rem;font-style:italic;overflow:hidden}.admin-btn{cursor:pointer;border:1px solid #0000;border-radius:.5rem;justify-content:center;align-items:center;padding:.5rem 1.125rem;font-family:inherit;font-size:.875rem;font-weight:600;transition:background .2s,border-color .2s,transform .1s,opacity .2s;display:inline-flex}.admin-btn:disabled{opacity:.55;cursor:not-allowed}.admin-btn-sm{padding:.375rem .875rem;font-size:.8125rem}.admin-btn:active:not(:disabled){transform:scale(.97)}.admin-btn-primary{background:var(--btn-bg);color:var(--btn-text);border-color:#0000}.admin-btn-primary:hover:not(:disabled){background:var(--btn-hover)}.admin-btn-secondary{background:var(--card-bg);color:var(--text);border-color:var(--card-border)}.admin-btn-secondary:hover:not(:disabled){background:var(--site-background);border-color:var(--highlight1);color:var(--highlight1)}.admin-btn-danger{color:#ef4444;background:#fee2e2;border-color:#fca5a5}.admin-btn-danger:hover:not(:disabled){background:#fecaca}@media (prefers-color-scheme:dark){.admin-btn-danger{background:#7f1d1d66;border-color:#b91c1c}.admin-btn-danger:hover:not(:disabled){background:#991b1b8c}}.admin-error{color:#ef4444;background:#fee2e2;border:1px solid #fca5a5;border-radius:.5rem;padding:.5rem .75rem;font-size:.875rem;font-weight:600}@media (prefers-color-scheme:dark){.admin-error{background:#7f1d1d66;border-color:#b91c1c}}.admin-empty{text-align:center;color:var(--text-muted);padding:3rem 1rem;font-size:1rem}.admin-inline-link{font-size:.9rem}.admin-service-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.admin-inline-icon{align-items:center;gap:.625rem;margin-top:.25rem;display:inline-flex}.admin-inline-icon-img{object-fit:contain;width:1.5rem;height:1.5rem;filter:var(--icon-filter)}.admin-inline-icon-name{color:var(--text-muted);font-size:.875rem}.admin-loading{flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;display:flex}.admin-icon-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.admin-service-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;display:grid}@media only screen and (max-width:600px){.admin-icon-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.admin-icon-card{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--shadow);border-radius:1rem;flex-direction:column;gap:.75rem;padding:1rem;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.admin-icon-card:hover{box-shadow:var(--shadow-hover);border-color:var(--highlight1);transform:translateY(-2px)}.admin-icon-card--editing{border-color:var(--highlight1);background:var(--card-bg);grid-column:span 2}@media only screen and (max-width:600px){.admin-icon-card--editing{grid-column:span 1}}.admin-icon-preview{background:0 0;border-radius:.625rem;justify-content:center;align-items:center;height:5rem;display:flex;overflow:hidden}.admin-icon-img{object-fit:contain;width:3rem;height:3rem;filter:var(--icon-filter)}.admin-icon-info{flex:1}.admin-icon-name{color:var(--text);text-align:center;word-break:break-word;font-size:1rem;font-weight:700}.admin-icon-actions{flex-wrap:wrap;gap:.5rem;display:flex}.admin-icon-edit{flex-direction:column;gap:.75rem;display:flex}.admin-service-card{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--shadow);border-radius:1rem;flex-direction:column;gap:1rem;padding:1.25rem;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex}.admin-service-card:hover{box-shadow:var(--shadow-hover);border-color:var(--highlight1);transform:translateY(-2px)}.admin-service-card--editing{border-color:var(--highlight1);background:var(--card-bg);grid-column:span 2}.admin-service-header{align-items:center;gap:1rem;display:flex}.admin-service-avatar{background:0 0;border-radius:.875rem;flex-shrink:0;justify-content:center;align-items:center;width:3.25rem;height:3.25rem;display:flex;overflow:hidden}.admin-service-avatar-img{object-fit:contain;width:2.5rem;height:2.5rem;filter:var(--icon-filter)}.admin-service-avatar-fallback{color:var(--highlight1);font-size:1.125rem;font-weight:800}.admin-service-meta{flex-direction:column;gap:.35rem;min-width:0;display:flex}.admin-service-topline{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.admin-service-title{color:var(--text);font-size:1.25rem;font-weight:700}.admin-service-category{background:var(--card-bg);border:1px solid var(--card-border);color:var(--highlight1);border-radius:999px;align-items:center;padding:.2rem .55rem;font-size:.75rem;font-weight:700;display:inline-flex}.admin-service-url{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;overflow:hidden}.admin-service-body,.admin-service-edit{flex-direction:column;gap:.9rem;display:flex}.admin-service-description{color:var(--text-muted)}.admin-service-chips{flex-wrap:wrap;gap:.5rem;display:flex}.admin-service-chip{background:var(--card-bg);border:1px solid var(--card-border);color:var(--text-muted);border-radius:999px;align-items:center;padding:.3rem .6rem;font-size:.75rem;font-weight:600;display:inline-flex}.admin-service-links{flex-wrap:wrap;gap:.875rem;display:flex}.admin-delete-confirm{flex-direction:column;gap:.5rem;display:flex}.admin-delete-msg{color:#ef4444;text-align:center;font-size:.8125rem;font-weight:600}@media only screen and (max-width:700px){.admin-service-form-grid{grid-template-columns:1fr}.admin-service-card--editing{grid-column:span 1}}.admin-modal-overlay{z-index:1000;background:#0009;position:fixed;inset:0}.admin-modal{z-index:1001;background:var(--card-bg);border:1px solid var(--card-border);width:calc(100% - 2rem);max-width:500px;max-height:90vh;box-shadow:0 25px 50px -12px #00000040,var(--shadow);border-radius:1.5rem;flex-direction:column;gap:1.5rem;padding:2rem;display:flex;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%)}@media (prefers-color-scheme:dark){.admin-modal-overlay{background:#000000b3}}.admin-modal-header{justify-content:space-between;align-items:center;gap:1rem;display:flex}.admin-modal-title{color:var(--text);margin:0;font-size:1.5rem;font-weight:700}.admin-modal-close{border:1px solid var(--card-border);width:2rem;height:2rem;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:.5rem;justify-content:center;align-items:center;font-size:1.5rem;transition:all .2s;display:flex}.admin-modal-close:hover{background:var(--site-background);border-color:var(--highlight1);color:var(--text)}.admin-modal-body,.admin-modal-content{flex-direction:column;gap:1.25rem;display:flex}.admin-modal-actions{border-top:1px solid var(--card-border);justify-content:flex-end;gap:.75rem;padding-top:.75rem;display:flex}.footer-container{text-align:center;border-top:1px solid #e5e7eb4d;max-width:1200px;margin:0 auto;padding:1.5rem 2rem}@media (prefers-color-scheme:dark){.footer-container{border-top-color:#3741514d}}.footer-text{color:var(--text-muted);margin:0;font-size:.875rem;line-height:1.5}.footer-text a{color:var(--highlight1-hover);font-weight:600;text-decoration:none;transition:opacity .2s}.footer-text a:hover{opacity:.8;text-decoration:underline}@media only screen and (max-width:900px){.footer-container{padding:1rem}.footer-text{font-size:.8rem}}