:root{--primary-dark: #151744;--primary-purple: #393392;--primary-light: #707CF1;--primary-pink: #F56E7B;--primary-white: #FFFFFF;--secondary-blue: #0076A2;--secondary-cyan: #00BBBA;--gray-light: #f5f5f5;--gray-medium: #e0e0e0;--gray-dark: #666666;--error-red: #dc3545;--success-green: #28a745}*{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;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--gray-light);color:var(--primary-dark)}.app{display:flex;min-height:100vh}.sidebar{width:280px;background:linear-gradient(180deg,var(--primary-dark) 0%,var(--primary-purple) 100%);color:var(--primary-white);padding:2rem 0;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000001a}.sidebar-header{padding:0 1.5rem 2rem;border-bottom:1px solid rgba(255,255,255,.2)}.sidebar-header h1{font-size:1.75rem;margin-bottom:.5rem;color:var(--primary-white)}.sidebar-header p{font-size:.9rem;color:#fffc}.sidebar-nav{flex:1;padding:1.5rem 0}.nav-item{padding:1rem 1.5rem;cursor:pointer;transition:all .3s;border-left:4px solid transparent;color:var(--primary-white)}.nav-item:hover{background-color:#ffffff1a;border-left-color:var(--primary-light)}.nav-item.active{background-color:#707cf133;border-left-color:var(--primary-light);font-weight:600}.main-content{flex:1;padding:2rem;overflow-y:auto}.content-header{margin-bottom:2rem}.content-header h2{font-size:2rem;color:var(--primary-dark);margin-bottom:.5rem}.content-header p{color:var(--gray-dark)}.card{background:var(--primary-white);border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #00000014}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.card-header h3{font-size:1.25rem;color:var(--primary-dark)}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s;font-weight:500;display:inline-flex;align-items:center;gap:.5rem}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--primary-purple) 0%,var(--primary-light) 100%);color:var(--primary-white)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #707cf14d}.btn-secondary{background-color:var(--secondary-blue);color:var(--primary-white)}.btn-secondary:hover:not(:disabled){background-color:#005f82}.btn-danger{background-color:var(--primary-pink);color:var(--primary-white)}.btn-danger:hover:not(:disabled){background-color:#f04555}.btn-outline{background-color:transparent;border:2px solid var(--primary-purple);color:var(--primary-purple)}.btn-outline:hover:not(:disabled){background-color:var(--primary-purple);color:var(--primary-white)}.btn-small{padding:.5rem 1rem;font-size:.875rem}.form-group{margin-bottom:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:0}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--primary-dark)}.form-control{width:100%;padding:.75rem;border:2px solid var(--gray-medium);border-radius:8px;font-size:1rem;transition:border-color .3s;font-family:inherit}.form-control:focus{outline:none;border-color:var(--primary-light)}textarea.form-control{resize:vertical;min-height:120px}select.form-control{cursor:pointer}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th{background-color:var(--primary-dark);color:var(--primary-white);padding:1rem;text-align:left;font-weight:600}.table td{padding:1rem;border-bottom:1px solid var(--gray-medium)}.table tbody tr:hover{background-color:#707cf10d}.table .action-buttons{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.table .action-buttons .btn{margin:0;white-space:nowrap}.loading{text-align:center;padding:3rem;color:var(--gray-dark)}.spinner{border:4px solid var(--gray-medium);border-top:4px solid var(--primary-light);border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.alert{padding:1rem 1.5rem;border-radius:8px;margin-bottom:1rem}.alert-success{background-color:#28a7451a;color:var(--success-green);border:1px solid var(--success-green)}.alert-error{background-color:#f56e7b1a;color:var(--primary-pink);border:1px solid var(--primary-pink)}.alert-info{background-color:#00bbba1a;color:var(--secondary-cyan);border:1px solid var(--secondary-cyan)}.modal-overlay{position:fixed;inset:0;background-color:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{background:var(--primary-white);border-radius:16px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0006;border:2px solid var(--primary-light);animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal{background:var(--primary-white);border-radius:12px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid var(--gray-light)}.modal-header h2,.modal-header h3{color:var(--primary-dark);font-size:1.5rem;margin:0}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gray-dark);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--primary-dark)}.modal-footer{margin-top:2rem;display:flex;gap:1rem;justify-content:flex-end}.file-upload{border:2px dashed var(--gray-medium);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .3s}.file-upload:hover{border-color:var(--primary-light);background-color:#707cf10d}.file-upload input[type=file]{display:none}.sow-preview{background-color:var(--gray-light);padding:2rem;border-radius:8px;max-height:500px;overflow-y:auto}.action-buttons{display:flex;gap:.5rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--gray-dark)}.empty-state-icon{font-size:4rem;color:var(--gray-medium);margin-bottom:1rem}@media(max-width:768px){.sidebar{width:100%;height:auto}.app{flex-direction:column}.main-content,.card{padding:1rem}.modal{width:95%;padding:1rem}}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.flex{display:flex}.justify-between{justify-content:space-between}.align-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-purple) 50%,var(--primary-light) 100%);padding:2rem}.login-card{background:var(--primary-white);border-radius:16px;padding:3rem;width:100%;max-width:450px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.login-header h1{font-size:2.5rem;color:var(--primary-dark);margin-bottom:.5rem}.login-header p{color:var(--gray-dark);font-size:1rem}.login-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-medium);text-align:center;color:var(--gray-dark);font-size:.9rem}.login-footer p{margin-bottom:.5rem}.btn-block{width:100%;justify-content:center}.link-button{background:none;border:none;color:var(--primary-light);cursor:pointer;text-decoration:underline;padding:0;font-size:inherit}.link-button:hover:not(:disabled){color:var(--primary-purple)}.user-info{padding:1rem 1.5rem;margin-bottom:1rem;display:flex;align-items:center;gap:1rem;background-color:#ffffff1a;border-radius:8px;margin:0 1rem 1.5rem}.user-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-light) 0%,var(--secondary-cyan) 100%);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.2rem;color:var(--primary-white);text-transform:uppercase}.user-details{flex:1}.user-name{font-weight:600;font-size:.95rem;margin-bottom:.25rem}.user-role{font-size:.8rem;color:#ffffffb3;text-transform:capitalize}.sidebar-footer{padding:1rem 1.5rem;margin-top:auto;border-top:1px solid rgba(255,255,255,.2)}.sidebar-footer .btn-outline{border-color:var(--primary-white);color:var(--primary-white)}.sidebar-footer .btn-outline:hover:not(:disabled){background-color:var(--primary-white);color:var(--primary-dark)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary-purple) 50%,var(--primary-light) 100%);color:var(--primary-white)}.loading-screen p{margin-top:1rem;font-size:1.1rem}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.badge-primary{background-color:var(--primary-light);color:var(--primary-white)}.badge-secondary{background-color:var(--gray-medium);color:var(--primary-dark)}.badge-success{background-color:var(--success-green);color:var(--primary-white)}.badge-danger{background-color:var(--primary-pink);color:var(--primary-white)}.form-group small{display:block;margin-top:.25rem;color:var(--gray-dark);font-size:.85rem}.dashboard-card{background:var(--primary-white);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;transition:transform .2s,box-shadow .2s}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.dashboard-card-title{font-size:.9rem;color:var(--gray-dark);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.dashboard-card-value{font-size:2.5rem;font-weight:700;color:var(--primary-purple);margin-bottom:.25rem}.dashboard-card-subtitle{font-size:.95rem;color:var(--gray-dark)}.dashboard-card-detail{font-size:.85rem;color:var(--gray-dark);margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--gray-light)}.dashboard-section{background:var(--primary-white);border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #00000014}.dashboard-section h2{font-size:1.5rem;color:var(--primary-dark);margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--primary-light)}.timeline-chart{display:flex;gap:1rem;align-items:flex-end;padding:2rem 1rem;overflow-x:auto;min-height:250px}.timeline-item{display:flex;flex-direction:column;align-items:center;flex:1;min-width:80px}.timeline-label{font-size:.75rem;color:var(--gray-dark);margin-bottom:.5rem;text-align:center;white-space:nowrap}.timeline-bars{display:flex;gap:.5rem;align-items:flex-end;height:150px}.timeline-bar-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}.timeline-bar{width:25px;border-radius:4px 4px 0 0;transition:all .3s;position:relative}.timeline-bar.generated{background:linear-gradient(180deg,var(--primary-light) 0%,var(--primary-purple) 100%)}.timeline-bar.uploaded{background:linear-gradient(180deg,var(--secondary-cyan) 0%,var(--secondary-blue) 100%)}.timeline-bar:hover{opacity:.8}.timeline-count{font-size:.7rem;color:var(--gray-dark);margin-top:.25rem;font-weight:600}.timeline-legend{display:flex;gap:2rem;justify-content:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--gray-light)}.timeline-legend div{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--gray-dark)}.legend-box{width:20px;height:20px;border-radius:4px}.legend-box.generated{background:linear-gradient(180deg,var(--primary-light) 0%,var(--primary-purple) 100%)}.legend-box.uploaded{background:linear-gradient(180deg,var(--secondary-cyan) 0%,var(--secondary-blue) 100%)}.resource-chart{display:flex;flex-direction:column;gap:1rem}.resource-item{display:grid;grid-template-columns:120px 1fr 150px;gap:1rem;align-items:center}.resource-label{font-size:.95rem;font-weight:600;color:var(--primary-dark)}.resource-bar-container{background:var(--gray-light);border-radius:8px;height:32px;overflow:hidden;position:relative}.resource-bar{height:100%;background:linear-gradient(90deg,var(--primary-light) 0%,var(--primary-purple) 100%);border-radius:8px;transition:width .5s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem}.resource-value{font-size:.9rem;font-weight:600;color:var(--primary-purple);text-align:right}.resource-total{margin-top:1rem;padding-top:1rem;border-top:2px solid var(--gray-light);font-size:1.1rem;font-weight:700;color:var(--primary-dark);text-align:right}.engagement-chart{display:flex;flex-direction:column;gap:1rem}.engagement-item{display:grid;grid-template-columns:200px 1fr 150px;gap:1rem;align-items:center}.engagement-label{font-size:.95rem;font-weight:600;color:var(--primary-dark)}.engagement-bar-container{background:var(--gray-light);border-radius:8px;height:32px;overflow:hidden;position:relative}.engagement-bar{height:100%;background:linear-gradient(90deg,var(--secondary-cyan) 0%,var(--secondary-blue) 100%);border-radius:8px;transition:width .5s ease}.engagement-value{font-size:.9rem;font-weight:600;color:var(--secondary-blue);text-align:right}@media(max-width:768px){.dashboard-card-value{font-size:2rem}.resource-item,.engagement-item{grid-template-columns:1fr;gap:.5rem}.resource-value,.engagement-value{text-align:left}.timeline-chart{justify-content:flex-start}}.template-content-view{font-family:Calibri,Arial,sans-serif;font-size:11pt;line-height:1.6;color:#000}.template-content-view h1{font-size:18pt;font-weight:700;margin-top:16px;margin-bottom:8px;color:#000}.template-content-view h2{font-size:16pt;font-weight:700;margin-top:14px;margin-bottom:6px;color:#000}.template-content-view h3{font-size:14pt;font-weight:700;margin-top:12px;margin-bottom:6px;color:#000}.template-content-view h4{font-size:12pt;font-weight:700;margin-top:10px;margin-bottom:4px;color:#000}.template-content-view p{margin-bottom:8px;margin-top:0}.template-content-view ul,.template-content-view ol{margin-left:20px;margin-bottom:8px;margin-top:8px}.template-content-view li{margin-bottom:4px}.template-content-view table{border-collapse:collapse;width:100%;margin-top:12px;margin-bottom:12px;font-size:10pt}.template-content-view th,.template-content-view td{border:1px solid #999;padding:6px 8px;text-align:left}.template-content-view th{background-color:#f0f0f0;font-weight:700}.template-content-view strong,.template-content-view b{font-weight:700}.template-content-view em,.template-content-view i{font-style:italic}.template-content-view a{color:#0563c1;text-decoration:underline}
