:root{--color-bg: #faf8f5;--color-bg-secondary: #f5f1ec;--color-bg-hover: #efe9e1;--color-bg-active: #e8dfd5;--color-bg-card: #ffffff;--color-text-primary: #1a1a1a;--color-text-secondary: #5c5549;--color-text-tertiary: #9c9488;--color-border: #e4ddd4;--color-border-light: #ede8e1;--color-accent: #b06a3b;--color-accent-hover: #96582f;--color-accent-bg: #faf0e6;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;--max-width: 680px;--transition: .15s ease}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;padding:0;min-height:100vh;background-color:var(--color-bg);color:var(--color-text-primary);font-family:var(--font-sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);font-weight:600;line-height:1.35;margin:0 0 .75rem}h1{font-size:1.875rem;font-weight:700;letter-spacing:-.025em}h2{font-size:1.25rem}h3{font-size:1.1rem}p{margin:0 0 1rem;line-height:1.7;color:var(--color-text-secondary)}code{font-family:var(--font-mono);background-color:var(--color-bg-secondary);padding:.125rem .375rem;border-radius:4px;font-size:.875em;border:1px solid var(--color-border)}pre{background-color:#2c2420;color:#e8dfd5;padding:1rem 1.25rem;border-radius:8px;overflow-x:auto;margin:1.25rem 0;font-size:.8125rem;line-height:1.65;border:1px solid #3d3530}pre code{background:none;padding:0;border:none;color:inherit}blockquote{border-left:2px solid var(--color-accent);margin:1.25rem 0;padding:.5rem 0 .5rem 1rem;color:var(--color-text-secondary)}.container{max-width:var(--max-width);margin:0 auto;padding:0 1.5rem}::selection{background-color:var(--color-accent-bg);color:var(--color-text-primary)}@media (max-width: 768px){body{font-size:14px}.container{padding:0 1rem}h1{font-size:1.5rem}}.header{position:sticky;top:0;z-index:100;height:56px;display:flex;align-items:center;background-color:#faf8f5d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border-light)}.nav{display:flex;justify-content:space-between;align-items:center;height:56px}.nav-logo{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;color:var(--color-text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;padding:.375rem 0;transition:opacity var(--transition)}.nav-logo:hover{opacity:.7}.logo-icon{width:24px;height:24px;border-radius:6px;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.nav-links{display:flex;gap:2px}.nav-link{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;padding:.375rem .75rem;border-radius:6px;transition:all var(--transition);-webkit-user-select:none;user-select:none}.nav-link:hover{color:var(--color-text-primary);background-color:var(--color-bg-hover)}.nav-link.active{color:var(--color-accent);background-color:var(--color-accent-bg)}@media (max-width: 768px){.header,.nav{height:48px}.nav-logo{font-size:.875rem}}.homepage{padding:2rem 0 3rem}.page-header{padding-bottom:1.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--color-border)}.page-header h1{margin:0 0 .25rem}.page-description{margin:0;font-size:.875rem;color:var(--color-text-tertiary)}.year-group{margin-bottom:.5rem}.year-label{font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:1.25rem 0 .5rem;position:sticky;top:56px;background:var(--color-bg);z-index:10}.posts-list{display:flex;flex-direction:column}.post-row{display:flex;align-items:flex-start;gap:1rem;padding:.625rem .5rem;margin:0 -.5rem;border-radius:8px;cursor:pointer;transition:background-color var(--transition)}.post-row:hover{background-color:var(--color-bg-card);box-shadow:0 1px 4px #0000000a}.post-row:active{background-color:var(--color-bg-hover)}.post-date{font-size:.8125rem;color:var(--color-text-tertiary);white-space:nowrap;flex-shrink:0;width:42px;padding-top:1px;font-variant-numeric:tabular-nums}.post-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.post-title{font-size:.9375rem;font-weight:500;color:var(--color-text-primary);transition:color var(--transition)}.post-row:hover .post-title{color:var(--color-accent)}.post-excerpt{font-size:.8125rem;color:var(--color-text-tertiary);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.post-arrow{flex-shrink:0;color:var(--color-text-tertiary);opacity:0;transform:translate(-4px);transition:all var(--transition);margin-top:2px}.post-row:hover .post-arrow{opacity:1;transform:translate(0)}.loading-state{display:flex;justify-content:center;gap:6px;padding:6rem 0}.loading-dot{width:6px;height:6px;border-radius:50%;background:var(--color-accent);animation:loadingPulse 1.2s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.15s}.loading-dot:nth-child(3){animation-delay:.3s}@keyframes loadingPulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.pagination{display:flex;justify-content:center;align-items:center;gap:.25rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border-light)}.page-btn{height:32px;padding:0 .75rem;border:1px solid var(--color-border);background:var(--color-bg-card);color:var(--color-text-secondary);cursor:pointer;border-radius:6px;font-size:.8125rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition)}.page-btn:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-accent);color:var(--color-accent)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.page-numbers{display:flex;gap:2px;margin:0 .5rem}.page-num{width:32px;height:32px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:6px;font-size:.8125rem;font-weight:500;font-family:var(--font-sans);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.page-num:hover:not(:disabled):not(.ellipsis){background:var(--color-bg-hover)}.page-num.active{background:var(--color-accent);color:#fff}.page-num.ellipsis{cursor:default;color:var(--color-text-tertiary)}@media (max-width: 768px){.homepage{padding:1.5rem 0 2rem}.year-label{top:48px}.post-row{flex-direction:column;gap:.25rem;padding:.5rem .375rem;margin:0 -.375rem}.post-date{width:auto;font-size:.75rem;order:-1}.post-title{font-size:.875rem}.post-arrow,.post-excerpt{display:none}.pagination{margin-top:1.5rem}}.post-page{padding:2rem 0 4rem}.post-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.back-link{display:inline-flex;align-items:center;gap:4px;background:none;border:none;font-size:.8125rem;font-weight:500;color:var(--color-text-tertiary);cursor:pointer;padding:0;margin-bottom:1.25rem;transition:color var(--transition);font-family:var(--font-sans)}.back-link:hover{color:var(--color-accent)}.post-page .post-title{font-size:1.75rem;font-weight:700;margin:0 0 .625rem;letter-spacing:-.025em;line-height:1.25}.post-meta{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--color-text-tertiary)}.meta-sep{color:var(--color-border)}.post-body{font-size:.9375rem;line-height:1.85;color:var(--color-text-secondary)}.post-body h1{font-size:1.375rem;margin:2rem 0 .75rem;color:var(--color-text-primary)}.post-body h2{font-size:1.175rem;margin:1.75rem 0 .625rem;color:var(--color-text-primary)}.post-body h3{font-size:1.05rem;margin:1.5rem 0 .5rem;color:var(--color-text-primary)}.post-body p{margin-bottom:1.125rem;line-height:1.85;color:var(--color-text-secondary)}.post-body strong{font-weight:600;color:var(--color-text-primary)}.post-body blockquote{margin:1.5rem 0;padding:.75rem 1rem;border-left:2px solid var(--color-accent);background:var(--color-bg-secondary);border-radius:0 6px 6px 0;color:var(--color-text-secondary)}.post-body blockquote p{margin:0}.post-body ul,.post-body ol{margin:1rem 0;padding-left:1.5rem}.post-body li{margin-bottom:.375rem;line-height:1.75;color:var(--color-text-secondary)}.post-body code{font-family:var(--font-mono);background:var(--color-bg-secondary);padding:.125rem .375rem;border-radius:4px;font-size:.85em;border:1px solid var(--color-border)}.post-body pre{background:#2c2420;color:#e8dfd5;padding:1rem 1.25rem;border-radius:8px;overflow-x:auto;margin:1.5rem 0;font-size:.8125rem;border:1px solid #3d3530}.post-body pre code{background:none;padding:0;border:none;color:inherit}.post-footer{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.empty-state{text-align:center;padding:4rem 0}.empty-state p{font-size:.9375rem;margin-bottom:1rem;color:var(--color-text-tertiary)}.post-page .loading-state{display:flex;justify-content:center;gap:6px;padding:6rem 0}.post-page .loading-dot{width:6px;height:6px;border-radius:50%;background:var(--color-accent);animation:loadingPulse 1.2s ease-in-out infinite}.post-page .loading-dot:nth-child(2){animation-delay:.15s}.post-page .loading-dot:nth-child(3){animation-delay:.3s}@media (max-width: 768px){.post-page{padding:1.25rem 0 3rem}.post-page .post-title{font-size:1.375rem}.post-body{font-size:.9rem;line-height:1.85}}.admin-login{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:2rem}.login-box{background:var(--color-bg-card);padding:2.5rem;border-radius:10px;border:1px solid var(--color-border);width:100%;max-width:360px;text-align:center;box-shadow:0 2px 8px #0000000a}.login-box h2{margin-bottom:1.5rem;font-size:1.125rem}.login-box input{width:100%;padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;margin-bottom:1rem;box-sizing:border-box;font-family:var(--font-sans);background:var(--color-bg);transition:border-color var(--transition)}.login-box input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.login-box button{width:100%;padding:.625rem;background:var(--color-accent);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:background var(--transition)}.login-box button:hover{background:var(--color-accent-hover)}.admin-dashboard{padding:2rem;max-width:1000px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.admin-header h1{margin:0;font-size:1.25rem}.admin-actions{display:flex;gap:.5rem}.btn-primary{background:var(--color-accent);color:#fff;padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;font-family:var(--font-sans);transition:background var(--transition)}.btn-primary:hover{background:var(--color-accent-hover)}.btn-secondary{background:transparent;color:var(--color-text-secondary);padding:.5rem 1rem;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition)}.btn-secondary:hover{background:var(--color-bg-hover)}.posts-list h2{margin-bottom:.75rem;font-size:1rem}.posts-table{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background:var(--color-bg-card)}.table-header{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;padding:.625rem 1rem;background:var(--color-bg-secondary);font-size:.75rem;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border)}.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1rem;padding:.625rem 1rem;border-bottom:1px solid var(--color-border-light);align-items:center;font-size:.8125rem}.table-row:last-child{border-bottom:none}.table-row:hover{background:var(--color-bg-secondary)}.post-title{font-weight:500;color:var(--color-text-primary)}.post-date,.post-author{color:var(--color-text-tertiary)}.post-actions{display:flex;gap:.375rem}.btn-edit,.btn-delete{padding:.25rem .625rem;border:1px solid var(--color-border);border-radius:4px;cursor:pointer;font-size:.75rem;font-family:var(--font-sans);background:transparent;transition:all var(--transition)}.btn-edit{color:var(--color-accent)}.btn-edit:hover{background:var(--color-accent-bg);border-color:var(--color-accent)}.btn-delete{color:#b04a3b}.btn-delete:hover{background:#faf0ec;border-color:#b04a3b}.admin-editor{padding:2rem;max-width:1200px;margin:0 auto}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.editor-header h2{margin:0;font-size:1.125rem}.editor-actions{display:flex;gap:.5rem}.editor-actions button{padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.8125rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition)}.editor-actions button:first-child{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border)}.editor-actions button:last-child{background:var(--color-accent);color:#fff;border:none}.editor-actions button:last-child:hover{background:var(--color-accent-hover)}.editor-actions button:disabled{opacity:.4;cursor:not-allowed}.editor-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;margin-bottom:.375rem;font-size:.8125rem;color:var(--color-text-primary)}.form-group input,.form-group textarea{padding:.625rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.875rem;font-family:var(--font-sans);resize:vertical;background:var(--color-bg-card);transition:border-color var(--transition)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-bg)}.content-editor{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;height:500px}.content-editor textarea{width:100%;height:100%;font-family:var(--font-mono);font-size:.8125rem;line-height:1.6;resize:none}.markdown-preview{border:1px solid var(--color-border);border-radius:6px;padding:1rem;overflow-y:auto;background:var(--color-bg-secondary)}.markdown-preview h4{margin:0 0 .75rem;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.preview-content{line-height:1.7;font-size:.875rem}.preview-content h1{font-size:1.25rem;margin-top:1rem}.preview-content h2{font-size:1.1rem;margin-top:.75rem}.preview-content p{margin-bottom:.75rem}.preview-content blockquote{border-left:2px solid var(--color-accent);margin:.75rem 0;padding:.375rem 0 .375rem .75rem;background:var(--color-bg-card);color:var(--color-text-secondary)}@media (max-width: 768px){.admin-dashboard,.admin-editor{padding:1rem}.admin-header,.editor-header{flex-direction:column;gap:.75rem}.table-header,.table-row{grid-template-columns:1fr;gap:.25rem}.content-editor{grid-template-columns:1fr;grid-template-rows:250px 250px;height:auto}.login-box{padding:1.5rem}}.about-page{padding:2rem 0 4rem;min-height:60vh}.about-page .page-header{padding-bottom:1.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.about-page .page-header h1{margin:0}.about-body{max-width:560px;font-size:.9375rem;line-height:1.85}.about-body p{margin-bottom:1.25rem;color:var(--color-text-secondary)}.about-page .loading-state{display:flex;justify-content:center;gap:6px;padding:6rem 0}.about-page .loading-dot{width:6px;height:6px;border-radius:50%;background:var(--color-accent);animation:loadingPulse 1.2s ease-in-out infinite}.about-page .loading-dot:nth-child(2){animation-delay:.15s}.about-page .loading-dot:nth-child(3){animation-delay:.3s}@media (max-width: 768px){.about-page{padding:1.5rem 0 3rem}.about-body{font-size:.9rem}}.app{min-height:100vh;display:flex;flex-direction:column;background-color:var(--color-bg)}#root{margin:0;padding:0}.page-content{flex:1}.site-footer{margin-top:auto;padding:2rem 0;text-align:center;color:var(--color-text-tertiary);font-size:.8125rem;border-top:1px solid var(--color-border-light)}.site-footer p{margin:0;color:var(--color-text-tertiary)}
