*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--dark-navy:#050d50;--navy:#004489;--grey:#323e48;--cyan:#6cf;--orange:#f7aa14;--white:#fff;--green:#3aaa35;--bg:#eef2f7}body{background:var(--bg);color:#222;font-family:Roboto,sans-serif;min-height:100vh}a{color:inherit;text-decoration:none}nav{align-items:center;background:var(--dark-navy);box-shadow:0 2px 8px rgba(0,0,0,.4);display:flex;gap:4px;height:56px;padding:0 20px;position:sticky;top:0;z-index:50}nav .brand{flex:1;font-size:20px;letter-spacing:.5px}nav .brand,nav a.nav-link{color:var(--orange);font-family:Oswald,sans-serif;font-weight:400}nav a.nav-link{border-radius:4px;font-size:14px;padding:6px 12px;transition:background .15s}nav a.nav-link:hover{background:rgba(247,170,20,.18)}nav a.nav-link.active{background:rgba(247,170,20,.25);font-weight:600}footer{background:var(--dark-navy);color:rgba(247,170,20,.6);font-size:11px;letter-spacing:.3px;padding:8px 16px;text-align:center}footer code{color:rgba(247,170,20,.85);font-family:monospace}main{margin:0 auto;max-width:1100px;padding:20px 16px 80px}.page-title{align-items:center;color:var(--dark-navy);display:flex;flex-wrap:wrap;font-family:Oswald,sans-serif;font-size:26px;gap:10px;margin-bottom:18px}.page-title .actions{display:flex;gap:8px;margin-left:auto}.project-grid{display:flex;flex-wrap:wrap;gap:12px}.btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-family:Roboto,sans-serif;font-size:14px;font-weight:500;gap:6px;padding:8px 18px;transition:opacity .15s,background .15s;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.45}.btn-primary{background:var(--orange);color:var(--dark-navy)}.btn-primary:hover{background:#e89e0d}.btn-outline{background:transparent;border:1.5px solid var(--navy);color:var(--navy)}.btn-outline:hover{background:rgba(0,68,137,.07)}.btn-danger{background:#c0392b;color:#fff}.btn-danger:hover{background:#a93226}.btn-ghost{background:transparent;border:none;color:var(--orange);cursor:pointer;font-size:16px;padding:4px 6px}.btn-sm{font-size:13px;padding:5px 12px}.fab{align-items:center;background:var(--dark-navy);border:none;border-radius:50%;bottom:28px;box-shadow:0 4px 14px rgba(0,0,0,.35);color:var(--orange);cursor:pointer;display:flex;font-size:30px;height:58px;justify-content:center;position:fixed;right:28px;transition:transform .15s;width:58px;z-index:40}.fab:hover{transform:scale(1.07)}.card{background:var(--navy);border-radius:10px;color:var(--white);display:block;padding:16px;transition:transform .15s,box-shadow .15s}.card.clickable{cursor:pointer}.card.clickable:hover{box-shadow:0 6px 18px rgba(0,0,0,.25);transform:translateY(-2px)}.stat-card{text-align:center}.stat-icon{font-size:22px;margin-bottom:4px}.stat-value{color:var(--orange);font-family:Oswald,sans-serif;font-size:34px;font-weight:600;line-height:1.1}.stat-label{color:hsla(0,0%,100%,.85);font-size:12px;font-weight:700;margin-top:2px}.project-card{display:flex;flex-direction:column;min-height:120px;padding:12px;position:relative;transition:transform .15s,box-shadow .15s;width:250px}.project-card:hover{box-shadow:0 6px 18px rgba(0,0,0,.25);transform:translateY(-2px)}.proj-card-link{border-radius:10px;inset:0;position:absolute;z-index:0}.proj-header{align-items:center;display:flex;gap:8px;margin-bottom:8px}.proj-type-icon{flex-shrink:0;font-size:22px}.project-card .proj-name{color:var(--white);flex:1;font-family:Oswald,sans-serif;font-size:13px;font-weight:500;word-break:break-word}.proj-footer{align-items:center;display:flex;justify-content:space-between;margin-top:auto;position:relative;z-index:1}.proj-actions{display:flex;gap:2px}.btn-icon{background:transparent;border:none;border-radius:4px;color:hsla(0,0%,100%,.6);cursor:pointer;font-size:15px;line-height:1;padding:3px 5px;transition:color .15s,background .15s}.btn-icon:hover{background:hsla(0,0%,100%,.12);color:var(--white)}.btn-icon-danger:hover{background:rgba(255,80,80,.15);color:#ff7070}.badge{border-radius:12px;display:inline-block;flex-shrink:0;font-size:11px;font-weight:700;padding:3px 10px;white-space:nowrap}.badge-todo{background:var(--grey);color:var(--white)}.badge-doing{background:var(--orange);color:var(--dark-navy)}.badge-done{background:var(--green);color:var(--dark-navy)}.badge-rejected{background:#c0392b;color:var(--white)}.badge-pass{background:var(--green);color:var(--dark-navy)}.badge-fail{background:#c0392b;color:var(--white)}.badge-skip{background:var(--grey);color:var(--white)}.badge-type-web{background:var(--cyan);color:var(--dark-navy)}.badge-type-mobileapp{background:var(--orange);color:var(--dark-navy)}.form-card{background:#fff;border-radius:10px;box-shadow:0 2px 12px rgba(0,0,0,.08);margin:0 auto;max-width:640px;padding:28px}.form-title{color:var(--dark-navy);font-family:Oswald,sans-serif;font-size:22px;margin-bottom:22px}.form-group{margin-bottom:18px}.form-group label{color:#555;display:block;font-size:13px;font-weight:600;letter-spacing:.3px;margin-bottom:6px;text-transform:uppercase}.form-group input,.form-group select,.form-group textarea{background:#fafafa;border:1.5px solid #d0d5dd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 14px;transition:border-color .15s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:var(--navy);outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f0f0f0;color:#666}.form-row{display:flex;gap:16px}.form-row .form-group{flex:1}.form-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}.modal-backdrop{align-items:center;background:rgba(0,0,0,.5);display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:200}.modal{background:#fff;border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.3);max-height:90vh;max-width:480px;min-width:300px;overflow-y:auto;padding:28px;width:100%}.modal h3{color:var(--dark-navy);font-family:Oswald,sans-serif;font-size:20px;margin-bottom:18px}.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:22px}.spinner{animation:spin .75s linear infinite;border:3px solid #ddd;border-radius:50%;border-top:3px solid var(--navy);height:42px;margin:60px auto;width:42px}@keyframes spin{to{transform:rotate(1turn)}}.empty{color:#999;font-size:15px;padding:50px 16px}.empty,.error{text-align:center}.error{color:#c0392b;font-size:14px;padding:40px 16px}.divider{border:none;border-top:1px solid #e5e5e5;margin:18px 0}.text-orange{color:var(--orange)}.text-cyan{color:var(--cyan)}.mt-8{margin-top:8px}.mb-16{margin-bottom:16px}