:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:#f5f5f5;overflow-x:hidden}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh}.login-box{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 10px #0000001a;width:100%;max-width:400px}.login-box h1{margin-bottom:1.5rem;text-align:center;color:#333}.login-box form{display:flex;flex-direction:column;gap:1rem}.login-box input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.login-box button{padding:.75rem;background:#007bff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.login-box button:hover{background:#0056b3}.kanban-container{min-height:100vh;display:flex;flex-direction:column}header{background:#007bff;color:#fff;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}header h1{font-size:1.5rem}.user-info{display:flex;gap:1rem;align-items:center}.user-info button{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid white;border-radius:4px;cursor:pointer}.user-info button:hover{background:#ffffff4d}main{flex:1;padding:2rem;overflow-x:auto}.error{background:#f8d7da;color:#721c24;padding:1rem;border-radius:4px;margin-bottom:1rem}.board{display:grid;grid-template-columns:repeat(4,minmax(280px,1fr));gap:1.5rem;min-width:1200px}.column{background:#e9ecef;border-radius:8px;padding:1rem;display:flex;flex-direction:column;max-height:calc(100vh - 150px)}.column-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #dee2e6}.column-header h2{font-size:1.1rem;color:#333}.count{background:#6c757d;color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.85rem;font-weight:600}.cards{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.75rem}.card{background:#fff;border-radius:6px;padding:1rem;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s}.card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.card h3{font-size:1rem;color:#333;margin-bottom:.5rem}.card .description{font-size:.9rem;color:#666;margin-bottom:.75rem;line-height:1.4}.card-footer{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;color:#999}.card-footer .time{color:#999}.card-footer .comments,.card-footer .updates{font-size:.8rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;border-radius:8px;width:90%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #dee2e6;position:sticky;top:0;background:#fff;z-index:1}.modal-header h2{font-size:1.3rem;color:#333}.close{background:none;border:none;font-size:2rem;color:#999;cursor:pointer;line-height:1;padding:0;width:30px;height:30px}.close:hover{color:#333}.modal-body{padding:1.5rem}.status-badge{display:inline-block;padding:.4rem .8rem;border-radius:4px;font-size:.85rem;font-weight:600;background:#6c757d;color:#fff;margin-bottom:1rem}.section{margin-bottom:1.5rem}.section h3{font-size:1rem;color:#333;margin-bottom:.75rem}.section p{color:#666;line-height:1.6}.update,.comment{background:#f8f9fa;padding:.75rem;border-radius:4px;margin-bottom:.5rem}.update small,.comment small{color:#999;font-size:.85rem}.update p,.comment p{margin-top:.5rem;color:#333}.comment strong{color:#007bff}.actions{border-top:1px solid #dee2e6;padding-top:1rem}.actions button{width:100%;padding:.75rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:.75rem}.btn-done{background:#28a745;color:#fff}.btn-done:hover{background:#218838}.actions form{display:flex;flex-direction:column;gap:.75rem}.actions textarea{width:100%;min-height:80px;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:.95rem;resize:vertical}.btn-revise{background:#ffc107;color:#000}.btn-revise:hover{background:#e0a800}.timestamps{display:flex;justify-content:space-between;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #dee2e6;color:#999;font-size:.85rem}
