html{box-sizing:border-box;font-size:16px;scroll-behavior:smooth}*,*:before,*:after{box-sizing:inherit}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f5f5f5;color:#000000de;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{display:flex;flex-direction:column;min-height:100vh}a{text-decoration:none;color:#1976d2;transition:color .3s ease}a:hover{color:#004ba0}img,video{max-width:100%;height:auto;display:block}button,input,textarea,select{font-family:inherit}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;padding:1rem;max-width:1200px;margin:0 auto}.error-banner{margin:1rem 0;padding:.75rem 1rem;background-color:#ffebee;color:#c62828;border:1px solid #f44336;border-radius:4px}.empty-state{text-align:center;margin:2rem 0}.empty-state h2{color:#666}.empty-state p{color:#666;margin-top:.5rem}.empty-state ul{display:inline-block;text-align:left;padding-left:1rem;margin-top:.5rem}.empty-state li{margin-bottom:.5rem}.app-header{background:#ffffff;padding:1rem;border-bottom:1px solid #e0e0e0}.header-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap}.header-title{margin:0;font-size:1.5rem;font-weight:700}.header-subtitle{font-size:.875rem;color:#666}.search-bar{display:flex;justify-content:center;margin:1rem 0}.search-input{flex:1;max-width:600px;padding:.5rem 1rem;border:1px solid #ccc;border-radius:4px 0 0 4px;font-size:1rem}.search-button{padding:.5rem 1rem;border:none;background-color:#1976d2;color:#fff;border-radius:0 4px 4px 0;cursor:pointer}.search-button:disabled{opacity:.6;cursor:default}.search-history{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.history-item,.history-clear{background:#f0f0f0;border:none;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.875rem}.history-clear{background:#e0e0e0}.history-item:hover,.history-clear:hover{background:#d5d5d5}.header-description{text-align:center;font-size:.875rem;color:#666;max-width:800px;margin:.5rem auto 0}
