*{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f5f5f5;--surface: #ffffff;--text: #1a1a1a;--text-muted: #555;--accent: #2563eb;--accent-hover: #1d4ed8;--border: #e5e7eb;--nav-bg: rgba(255, 255, 255, .95);--shadow: rgba(0, 0, 0, .08)}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--text: #f1f5f9;--text-muted: #94a3b8;--accent: #3b82f6;--accent-hover: #60a5fa;--border: #334155;--nav-bg: rgba(30, 41, 59, .95);--shadow: rgba(0, 0, 0, .3)}html{scroll-behavior:smooth}body{width:100%;min-height:100vh;display:flex;flex-direction:column;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);transition:background .3s ease,color .3s ease}.header{position:sticky;top:0;z-index:100;background:var(--bg);width:100%}.header-inner{max-width:1200px;margin:0 auto;padding:0 1.25rem}.heading{padding:1.5rem 0 .75rem;text-align:center}.heading .site-title{font-size:clamp(1.5rem,5vw,2.25rem);font-weight:700;letter-spacing:-.02em}.tagline{margin-top:.25rem;font-size:clamp(.875rem,2.5vw,1rem);color:var(--text-muted)}.nav-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;min-height:3rem;padding:.625rem .75rem .875rem;background:var(--nav-bg);border-radius:0 0 12px 12px}.service-status{margin-top:.5rem;padding:.55rem .75rem;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.82rem;font-weight:600}.service-status.ok{border-color:#16a34a}.service-status.bad{border-color:#dc2626}.service-status-meta{display:block;margin-top:.2rem;color:var(--text-muted);font-weight:500}.nav-left{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .75rem}.nav-bar a{color:var(--text);text-decoration:none;font-size:.9375rem;font-weight:500;padding:.5rem .75rem;border-radius:8px;transition:background .2s,color .2s;display:inline-flex;align-items:center}.nav-bar a:hover{background:var(--accent);color:#fff}.nav-home{gap:.4rem}.home-icon{width:1.25rem;height:1.25rem;flex-shrink:0}.theme-toggle{display:flex;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;flex-shrink:0;padding:0;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);cursor:pointer;transition:background .2s,border-color .2s,transform .15s}.theme-toggle:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.theme-toggle:active{transform:scale(.96)}.theme-toggle .icon-moon,[data-theme=dark] .theme-toggle .icon-sun{display:none}[data-theme=dark] .theme-toggle .icon-moon{display:block}.theme-toggle svg{width:1.35rem;height:1.35rem}.nav-toggle{display:none;align-items:center;justify-content:center;width:2.75rem;height:2.75rem;padding:0;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);cursor:pointer;flex-direction:column;gap:5px;transition:background .2s,border-color .2s}.nav-toggle:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.nav-toggle-bar{display:block;width:1.15rem;height:2px;background:currentColor;border-radius:1px;transition:transform .25s ease,opacity .2s ease}.nav-bar.is-open .nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-bar.is-open .nav-toggle-bar:nth-child(2){opacity:0}.nav-bar.is-open .nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.page-layout{flex:1;display:flex;align-items:flex-start;gap:1.5rem;width:100%;max-width:1200px;margin:0 auto;margin-top:1.5rem;min-height:0;padding:0 1.25rem}.sidebar{width:260px;flex-shrink:0;padding:1.25rem 1rem;background:var(--surface);border-left:1px solid var(--border)}.sidebar-search{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem}.sidebar-search input{flex:1;min-width:0;height:2.25rem;padding:0 .75rem;border:1px solid var(--border);border-radius:8px;background:var(--bg);color:var(--text);font-size:.875rem}.sidebar-search input::placeholder{color:var(--text-muted)}.sidebar-search button{height:2.25rem;padding:0 1rem;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;flex-shrink:0;transition:background .2s}.sidebar-search button:hover{background:var(--accent-hover)}[data-theme=dark] .sidebar-search button{background:var(--accent);color:#fff}.sidebar-heading{font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text);margin-bottom:.75rem;padding-left:.25rem}.sidebar-categories{display:flex;flex-direction:column}.sidebar-categories a{display:flex;align-items:center;gap:.5rem;padding:.6rem .25rem;color:var(--text-muted);text-decoration:none;font-size:.875rem;border-bottom:1px solid var(--border);transition:color .2s}.sidebar-categories a:hover{color:var(--accent)}.sidebar-icon{width:1rem;height:1rem;flex-shrink:0;opacity:.7}.main{flex:1;min-width:0;padding:1.5rem 0;width:100%}.main h1,.main h2{margin-bottom:.5rem;font-size:1.5rem}.main p{color:var(--text-muted);line-height:1.6}.content-box{max-width:42rem;padding:1.5rem 1.25rem;line-height:1.65}.content-box h1,.content-box h2{margin-bottom:1.25rem;font-size:1.5rem}.content-box p{margin-bottom:1rem}.content-box p:last-child{margin-bottom:0}.content-box--left{margin-right:auto}.contact-box{max-width:720px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.25rem}.contact-box h2{margin-bottom:.35rem}.contact-box>p{margin-bottom:1rem;color:var(--text-muted)}.contact-form{display:grid;gap:.6rem}.contact-form label{font-weight:600;color:var(--text-muted)}.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--border);border-radius:8px;padding:.65rem .75rem;background:var(--bg);color:var(--text);font:inherit}.contact-email-note{margin-top:1rem;font-size:.95rem}.contact-status{margin-top:.85rem;color:var(--text-muted);font-size:.9rem}.contact-email-note a{color:var(--accent);text-decoration:none}.contact-email-note a:hover{text-decoration:underline}.footer{margin-top:auto;padding:1.25rem 1.25rem 1.5rem;background:var(--surface);border-top:1px solid var(--border)}.footer-inner{max-width:1200px;margin:0 auto;padding:0 1.25rem;text-align:center}.footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem 1.25rem;margin-bottom:.75rem}.footer-links a{color:var(--text-muted);text-decoration:none;font-size:.875rem;transition:color .2s}.footer-links a:hover{color:var(--accent)}.footer-copy{font-size:.8125rem;color:var(--text-muted)}@media (max-width: 900px){.page-layout{flex-direction:column;padding:0 1rem}.sidebar{width:100%;border-left:none;border-top:1px solid var(--border);padding:1rem}.main{padding:1.25rem 0}}@media (max-width: 768px){.header-inner{padding:0 1rem}.nav-bar{flex-wrap:wrap;min-height:auto;padding:.5rem .75rem;gap:0;align-items:center;justify-content:space-between}.nav-toggle{display:flex;order:1}.theme-toggle{order:2;width:2.75rem;height:2.75rem}.theme-toggle svg{width:1.2rem;height:1.2rem}.nav-left{order:3;width:100%;flex-basis:100%;max-height:0;overflow:hidden;opacity:0;flex-direction:column;align-items:stretch;gap:0;padding-top:0;border-top:none;transition:max-height .3s ease,opacity .2s ease,padding .2s ease}.nav-bar.is-open .nav-left{max-height:320px;opacity:1;padding-top:.75rem;margin-top:.5rem;border-top:1px solid var(--border)}.nav-bar a{display:flex;align-items:center;padding:.75rem 1rem;font-size:1rem;border-radius:8px;margin-bottom:.25rem;border:1px solid transparent}.nav-bar a:last-child{margin-bottom:0}.nav-bar a:hover{background:var(--accent);color:#fff}.nav-home{justify-content:flex-start}.page-layout{padding:0 1rem}.sidebar-search{flex-wrap:wrap}.sidebar-search input{flex:1;min-width:120px}.footer-inner{padding:0 1rem}}@media (max-width: 480px){.heading{padding:1.25rem 0 .5rem}.sidebar{padding:1rem .75rem}.footer-links{flex-direction:column;align-items:center;gap:.5rem}}.read-card{width:100%;max-width:100%;margin:0;padding:1.5rem;border:3px solid #111;background:var(--surface)}.read-card-image-wrap{border:3px solid #111;overflow:hidden;background:var(--bg)}.read-card-image-wrap img{width:100%;height:auto;object-fit:contain;display:block}.img-lqip-wrap{position:relative;background-color:#e5e7eb;background-size:cover;background-position:center}.img-lqip-wrap img{opacity:0;transition:opacity .35s ease}.img-lqip-wrap.is-loaded img{opacity:1}.read-card-body{min-height:210px;padding:1.5rem 0 .5rem;display:flex;flex-direction:column}.read-card-body h2{margin-bottom:.75rem;font-size:clamp(1.25rem,3vw,1.7rem)}.read-card-body p{margin-bottom:1.25rem;line-height:1.7;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.read-card-btn{display:inline-flex;align-items:center;align-self:flex-start;gap:.45rem;border:2px solid #111;padding:.55rem .9rem;background:#fff;color:#111;text-decoration:none;font-weight:600;transition:background .2s ease,color .2s ease;margin-top:auto}.read-card-btn:hover{background:#111;color:#fff}.post-card-actions{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:auto}.post-card-actions .read-card-btn{margin-top:0}.post-detail-actions{margin-top:1rem}.post-popup-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:grid;place-items:center}.post-popup-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3}.post-popup-box{position:relative;z-index:1;width:min(92vw,520px);max-height:86vh;background:var(--surface);border-radius:12px;padding:.85rem;border:1px solid var(--border);box-shadow:0 16px 44px #00000059}.post-popup-box img{width:100%;height:auto;display:block;border-radius:8px}.post-popup-image{width:100%;display:block;border-radius:8px;overflow:hidden}.post-popup-image img{width:100%;height:auto;display:block}.post-popup-close{position:absolute;top:.35rem;right:.35rem;width:2rem;height:2rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);color:var(--text);font-size:1.3rem;line-height:1;cursor:pointer}.post-btn-icon{width:1rem;height:1rem;object-fit:cover;border-radius:2px}.post-btn-icon-wrap{display:inline-flex;align-items:center;justify-content:center;width:1rem;height:1rem}.posts-feed{display:grid;gap:1.25rem}.feed-header h1{margin-bottom:.35rem;font-size:clamp(1.3rem,3vw,1.9rem)}.feed-header p,.feed-empty{color:var(--text-muted)}.search-section{display:grid;gap:.75rem}.search-section h2{font-size:1.15rem}.search-links{display:flex;flex-wrap:wrap;gap:.5rem}.search-tag{display:inline-flex;align-items:center;padding:.4rem .7rem;border:1px solid var(--border);border-radius:999px;background:var(--surface);font-size:.85rem;color:var(--text)}.search-results{display:grid;gap:1rem}.feed-skeleton{display:grid;gap:1.25rem}.skeleton-block{background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.2s ease-in-out infinite}.skeleton-line{height:.9rem;margin-bottom:.6rem;border-radius:999px;background:linear-gradient(90deg,#e5e7eb,#f3f4f6,#e5e7eb);background-size:200% 100%;animation:skeleton-shimmer 1.2s ease-in-out infinite}.skeleton-title{height:1.2rem;width:70%}.skeleton-btn{width:40%;height:1.1rem;margin-top:1rem}@keyframes skeleton-shimmer{0%{background-position:0% 50%}to{background-position:200% 50%}}.pagination{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;align-items:center;margin-top:.5rem}.pagination-link{display:inline-flex;align-items:center;justify-content:center;min-width:2.25rem;height:2.25rem;padding:0 .75rem;border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text);background:var(--surface);font-weight:600;transition:background .2s ease,color .2s ease,border-color .2s ease}.pagination-link:hover,.pagination-link.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}.pagination-next{min-width:3.5rem}.admin-page{max-width:900px;margin:2rem auto;padding:0 1rem 2rem}.admin-theme-bar{display:flex;justify-content:flex-end;margin-bottom:.8rem}.admin-site-nav{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.9rem;padding:.6rem;border:1px solid var(--border);border-radius:12px;background:var(--surface);box-shadow:0 6px 16px var(--shadow)}.admin-site-link{display:inline-flex;align-items:center;padding:.45rem .8rem;border-radius:999px;border:1px solid var(--border);background:var(--bg);color:var(--text);text-decoration:none;font-size:.85rem;font-weight:600;transition:background .2s ease,color .2s ease,border-color .2s ease}.admin-site-link:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.admin-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.25rem;box-shadow:0 8px 24px var(--shadow)}.admin-panel-hidden{display:none}.admin-panel h1{margin-bottom:.5rem}.admin-form{display:grid;gap:.85rem;margin-top:1rem}.admin-form label{display:grid;gap:.35rem;color:var(--text-muted);font-weight:600}.admin-form input,.admin-form select,.admin-form textarea{width:100%;border:1px solid var(--border);border-radius:8px;padding:.65rem .75rem;background:var(--bg);color:var(--text);font:inherit}.admin-message{margin-top:.75rem;color:var(--text-muted)}.admin-note{margin-top:-.35rem;margin-bottom:.1rem;color:var(--text-muted);font-size:.82rem}.admin-top-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.admin-subtitle{margin-top:1.25rem;margin-bottom:.75rem}.admin-post-list{display:grid;gap:.75rem}.admin-post-item{display:grid;grid-template-columns:92px 1fr auto;gap:.75rem;align-items:center;border:1px solid var(--border);border-radius:10px;padding:.6rem;background:var(--bg)}.admin-post-thumb{width:92px;height:62px;border-radius:8px;overflow:hidden}.admin-post-thumb img{width:100%;height:100%;object-fit:cover;display:block}.admin-post-item h3{margin-bottom:.25rem;font-size:1rem}.admin-post-item p{color:var(--text-muted);font-size:.875rem;margin-bottom:.2rem}.admin-post-meta{display:flex;flex-wrap:wrap;gap:.35rem .75rem;color:var(--text-muted);font-size:.8rem;font-weight:600}.admin-post-actions{display:grid;gap:.45rem;justify-items:start}.post-page{max-width:960px;margin:1.75rem auto 2.25rem;padding:0 1rem}.post-detail{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:1.25rem;box-shadow:0 8px 24px var(--shadow)}.post-detail h1{margin-top:1rem;margin-bottom:.5rem;font-size:clamp(1.4rem,3.3vw,2rem)}.post-meta{color:var(--text-muted);margin-bottom:1rem}.post-image-wrap{border:2px solid #111;border-radius:10px;overflow:hidden;margin-bottom:1rem}.post-image-wrap img{width:100%;height:auto;object-fit:contain;display:block}.post-content p{margin-bottom:1rem;line-height:1.8}@media (max-width: 480px){.read-card{padding:1rem}.read-card-body{padding-top:1rem}.admin-post-item,.admin-post-actions{grid-template-columns:1fr}}
