body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{margin-left:250px}.main-content{min-height:100vh}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.App{margin-left:200px}}.sidebar{background-color:#2c3e50;color:#fff;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;width:250px;z-index:1000}.sidebar-header{background-color:#1a252f;border-bottom:1px solid #34495e;padding:20px}.sidebar-header h2{color:#fff;font-size:1.5rem;margin:0}.sidebar-menu{display:flex;flex-direction:column;list-style-type:none;margin:0;padding:0;width:100%}.menu-section{border-bottom:1px solid #34495e;display:block;width:100%}.menu-section-header{align-items:center;box-sizing:border-box;cursor:pointer;display:flex;padding:14px 10px;transition:background-color .2s ease;width:100%}.menu-section-header:hover{background-color:#34495e}.expand-icon{color:#bdc3c7;display:inline-block;font-size:.8rem;transition:transform .2s ease;-webkit-user-select:none;user-select:none;width:20px}.menu-link-inline{color:#fff;flex:1 1;font-size:1rem;font-weight:600;text-decoration:none}.menu-link-inline:hover{color:#3498db}.admin-icon{font-size:1rem}.admin-icon,.admin-link{color:#ffc107}.admin-link:hover{color:#ffca28}.auth-icon{color:#3498db;font-size:1.1rem}.logout-button{background:none;border:none;color:#e74c3c;cursor:pointer;flex:1 1;font-family:inherit;font-size:1rem;font-weight:600;padding:0;text-align:left;text-decoration:none}.logout-button:hover{color:#c0392b}.login-link{color:#3498db}.login-link:hover{color:#2980b9}.submenu-tree{animation:slideDown .2s ease-out;background-color:#1e2d3b;display:flex;flex-direction:column;list-style-type:none;margin:0;padding:0;width:100%}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:500px;opacity:1}}.submenu-tree li{border-top:1px solid #2c3e50;display:block;width:100%}.submenu-link{box-sizing:border-box;color:#bdc3c7;display:block;font-size:.9rem;overflow:hidden;padding:10px 20px 10px 40px;text-decoration:none;text-overflow:ellipsis;transition:all .2s ease;white-space:nowrap;width:100%}.submenu-link:hover{background-color:#2c3e50;color:#fff;padding-left:45px}.submenu-link:active{background-color:#3498db}@media (max-width:768px){.sidebar{width:200px}.sidebar-header h2{font-size:1.2rem}.menu-link-inline{font-size:.95rem}.submenu-link{font-size:.85rem;padding:8px 15px 8px 30px}.submenu-link:hover{padding-left:35px}}.home-container{background-color:#f5f5f5;min-height:100vh}.news-list-container{margin:0 auto;max-width:1200px;padding:20px}.news-list-container h1{color:#333;font-size:2.5rem;margin-bottom:10px}.news-loading{color:#666;font-size:1.2rem;padding:40px;text-align:center}.news-error{background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;margin-bottom:20px;padding:12px}.news-error p{color:#856404;margin:0}.news-error code{background-color:#fff;border-radius:3px;font-family:monospace;padding:2px 6px}.news-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:20px}.news-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 2px 4px #0000001a;color:inherit;padding:20px;text-decoration:none;transition:all .3s ease}.news-card:hover{border-color:#007bff;box-shadow:0 4px 12px #00000026;transform:translateY(-4px)}.news-card-content h2{color:#333;font-size:1.5rem;margin:0 0 10px}.news-meta{color:#666;font-size:.9rem;margin-bottom:12px}.news-date{font-weight:500}.news-author{color:#999}.news-summary{color:#555;line-height:1.6;margin-bottom:12px}.read-more{color:#007bff;font-size:.95rem;font-weight:500}.news-card:hover .read-more{text-decoration:underline}@media (max-width:768px){.news-grid{grid-template-columns:1fr}.news-list-container h1{font-size:2rem}}.tools-page{margin:0 auto;max-width:1200px;padding:40px 20px}.tools-page h1{color:#333;font-size:2.5rem;margin-bottom:10px}.tools-description{color:#666;font-size:1.1rem;margin-bottom:40px}.tools-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.tool-card-link{color:inherit;text-decoration:none}.tool-card-detail{background:#fff;border:2px solid #e0e0e0;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;height:100%;padding:30px;transition:all .3s ease}.tool-card-detail:hover{border-color:#28a745;box-shadow:0 8px 24px #00000026;transform:translateY(-8px)}.tool-icon{font-size:3rem;margin-bottom:15px}.tool-card-detail h2{color:#28a745;font-size:1.5rem;margin:0 0 15px}.tool-card-detail p{color:#555;flex-grow:1;line-height:1.6;margin-bottom:20px}.tool-action{color:#28a745;font-size:1rem;font-weight:600}.tool-card-detail:hover .tool-action{text-decoration:underline}@media (max-width:768px){.tools-page{padding:20px 10px}.tools-page h1{font-size:2rem}.tools-grid{grid-template-columns:1fr}}.tool-section{margin-bottom:30px}.result-section{margin-top:40px}.result-item{background-color:#f8f9fa;border-left:4px solid #28a745;border-radius:6px;display:flex;justify-content:space-between;margin-bottom:10px;padding:15px}.result-label{color:#555;font-weight:600}.result-value{color:#28a745;font-size:1.1rem;font-weight:500}@media (max-width:768px){.tool-page-container{padding:20px 10px}.tool-page-content{padding:25px}.tool-page-content h1{font-size:2rem}.result-item{flex-direction:column;gap:8px}}.tool-page-container{max-width:800px}.input-group{display:flex;gap:10px}.length-input{border:2px solid #e0e0e0;border-radius:6px;flex:1 1;font-size:1rem;padding:12px 15px;transition:border-color .2s}.length-input:focus{border-color:#3498db;outline:none}.unit-select{background-color:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:1rem;min-width:120px;padding:12px 15px;transition:border-color .2s}.unit-select:focus{border-color:#3498db;outline:none}.convert-button{background-color:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-bottom:20px;padding:12px 30px;transition:background-color .2s}.convert-button:hover{background-color:#218838}.convert-button:active{transform:scale(.98)}.conversion-result{background-color:#f8f9fa;border-left:4px solid #28a745;border-radius:6px;color:#333;font-size:1.2rem;font-weight:500;padding:20px}@media (max-width:768px){.tool-page-container{padding:20px 10px}.tool-page-content{padding:25px}.tool-page-content h1{font-size:2rem}.input-group{flex-direction:column}.unit-select{width:100%}}.tool-page-container{background-color:#f5f5f5;margin:0 auto;max-width:900px;min-height:100vh;padding:40px 20px}.tool-page-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:40px}.tool-page-content h1{color:#333;font-size:2.5rem;margin:0 0 15px}.tool-description{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:30px}.tool-section{margin-bottom:20px}.tool-label{color:#333;display:block;font-size:1.1rem;font-weight:600;margin-bottom:10px}.json-input{border:2px solid #e0e0e0;border-radius:6px;box-sizing:border-box;font-family:Courier New,monospace;font-size:.95rem;height:250px;padding:15px;resize:vertical;transition:border-color .2s;width:100%}.json-input:focus{border-color:#3498db;outline:none}.format-button{background-color:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-bottom:20px;padding:12px 30px;transition:background-color .2s}.format-button:hover{background-color:#218838}.format-button:active{transform:scale(.98)}.error-message{background-color:#f8d7da;border-left:4px solid #d32f2f;border-radius:6px;color:#721c24;font-weight:500;margin-bottom:20px;padding:15px}.result-section{border-top:2px solid #e0e0e0;margin-top:30px;padding-top:30px}.result-section h2{color:#333;font-size:1.8rem;margin:0 0 20px}.formatted-output{word-wrap:break-word;background-color:#f8f9fa;border:2px solid #e0e0e0;border-radius:6px;font-family:Courier New,monospace;font-size:.95rem;line-height:1.6;overflow-x:auto;padding:20px;white-space:pre-wrap}@media (max-width:768px){.tool-page-container{padding:20px 10px}.tool-page-content{padding:25px}.tool-page-content h1{font-size:2rem}.json-input{height:200px}}.news-detail-container{margin:0 auto;max-width:800px;padding:20px}.news-detail-loading{color:#666;font-size:1.2rem}.news-detail-error,.news-detail-loading{padding:40px;text-align:center}.news-detail-error h1{color:#d32f2f;margin-bottom:20px}.back-link{color:#007bff;display:inline-block;font-weight:500;margin-bottom:20px;text-decoration:none;transition:color .2s}.back-link:hover{color:#0056b3;text-decoration:underline}.news-article{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:30px}.article-header{border-bottom:2px solid #e0e0e0;margin-bottom:30px;padding-bottom:20px}.article-header h1{color:#333;font-size:2.5rem;line-height:1.2;margin:0 0 15px}.article-meta{color:#666;font-size:.95rem}.article-date{font-weight:500}.article-author{color:#999}.article-content{color:#333;font-size:1.1rem;line-height:1.8}.article-content p{margin-bottom:1.2em}.article-content h2{color:#333;font-size:1.8rem;margin-bottom:.8em;margin-top:1.5em}.article-content h3{color:#444;font-size:1.4rem;margin-bottom:.6em;margin-top:1.3em}.article-content ol,.article-content ul{margin-bottom:1.2em;padding-left:2em}.article-content li{margin-bottom:.5em}.article-content blockquote{border-left:4px solid #007bff;color:#555;font-style:italic;margin:1.5em 0;padding-left:20px}.article-content code{background-color:#f5f5f5;border-radius:3px;font-family:Courier New,monospace;font-size:.9em;padding:2px 6px}.article-content pre{background-color:#f5f5f5;border-radius:4px;margin:1.2em 0;overflow-x:auto;padding:15px}.article-content pre code{background:none;padding:0}.api-note{background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;margin-top:30px;padding:12px}.api-note p{color:#856404;font-size:.9rem;margin:0}.api-note code{background-color:#fff;border-radius:3px;font-family:monospace;padding:2px 6px}@media (max-width:768px){.news-detail-container{padding:10px}.news-article{padding:20px}.article-header h1{font-size:2rem}.article-content{font-size:1rem}.article-content h2{font-size:1.5rem}}.admin-page-container{background-color:#f5f5f5;margin:0 auto;max-width:900px;min-height:100vh;padding:40px 20px}.admin-page-content{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:40px}.admin-page-content h1{color:#333;font-size:2.5rem;margin:0 0 15px}.admin-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:30px}.admin-description{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:0}.admin-user-info{background-color:#e3f2fd;border-radius:6px;color:#1976d2;font-size:.95rem;padding:10px 20px;white-space:nowrap}.admin-user-info strong{color:#0d47a1}.admin-message{border-radius:6px;font-weight:500;margin-bottom:25px;padding:15px 20px}.admin-message.success{background-color:#d4edda;border-left:4px solid #28a745;color:#155724}.admin-message.error{background-color:#f8d7da;border-left:4px solid #d32f2f;color:#721c24}.admin-form{gap:25px}.admin-form,.form-group{display:flex;flex-direction:column}.form-label{color:#333;font-size:1.05rem;font-weight:600;margin-bottom:8px}.required{color:#d32f2f}.form-input{border:2px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:1rem;padding:12px 15px;transition:border-color .2s}.form-input:focus{border-color:#3498db;outline:none}.form-textarea{border:2px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:1rem;line-height:1.6;padding:12px 15px;resize:vertical;transition:border-color .2s}.form-textarea.short{min-height:80px}.form-textarea:focus{border-color:#3498db;outline:none}.form-help{color:#666;font-size:.9rem;font-style:italic;margin-top:6px}.form-actions{display:flex;gap:15px;margin-top:10px}.submit-button{background-color:#007bff;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-size:1.1rem;font-weight:600;padding:14px 30px;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:#0056b3}.submit-button:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.submit-button:active:not(:disabled){transform:scale(.98)}.cancel-button{background-color:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:14px 30px;transition:background-color .2s}.cancel-button:hover{background-color:#5a6268}.cancel-button:active{transform:scale(.98)}@media (max-width:768px){.admin-page-container{padding:20px 10px}.admin-page-content{padding:25px}.admin-page-content h1{font-size:2rem}.admin-header{flex-direction:column;gap:15px}.admin-user-info{align-self:flex-start}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:450px;padding:50px 40px;width:100%}.login-box h1{color:#333;font-size:2.2rem;margin:0 0 10px;text-align:center}.login-description{color:#666;font-size:1rem;margin-bottom:30px;text-align:center}.login-error{background-color:#f8d7da;border-left:4px solid #d32f2f;border-radius:6px;color:#721c24;font-size:.95rem;margin-bottom:20px;padding:12px 15px}.login-form{gap:20px}.login-form,.login-form-group{display:flex;flex-direction:column}.login-label{color:#333;font-size:.95rem;font-weight:600;margin-bottom:8px}.login-input{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;padding:14px 15px;transition:all .2s}.login-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:10px;padding:14px 30px;transition:all .2s}.login-button:hover:not(:disabled){box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-button:active:not(:disabled){transform:translateY(0)}.login-demo-info{border-top:2px solid #e0e0e0;margin-top:30px;padding-top:20px;text-align:center}.login-demo-info p{color:#666;font-size:.9rem;margin:5px 0}.login-demo-info strong{color:#333}.login-demo-info code{background-color:#f5f5f5;border-radius:4px;color:#d32f2f;font-family:Courier New,monospace;font-weight:600;padding:3px 8px}@media (max-width:768px){.login-box{padding:40px 30px}.login-box h1{font-size:1.8rem}}
/*# sourceMappingURL=main.a86d4aac.css.map*/