@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&family=Open+Sans:wght@300;400;600;700&display=swap");:root{--dufeu-blue:#6CACE4;--dufeu-blue-hover:#5a9ad2;--dufeu-green:#96d404;--dufeu-green-hover:#85bd03;--dufeu-teal:#127691;--dufeu-indigo:#1C2133;--dufeu-iris:#6477BA;--grey-dark:#4E4E4F;--grey-medium:#818285;--grey-light:#BEBEBF;--off-white:#F2F2F2;--white:#FFFFFF;--gradient-dufeu:linear-gradient(135deg,#96d404,#6CACE4);--gradient-dufeu-full:linear-gradient(135deg,#96d404,#6FC2BC 33%,#6CACE4 66%,#6477BA);--gradient-bar:linear-gradient(90deg,#127691,#6CACE4 50%,#96d404);--font-heading:"Poppins","Segoe UI",system-ui,sans-serif;--font-body:"Open Sans","Segoe UI",system-ui,sans-serif;--shadow-sm:0 1px 2px rgba(28,33,51,0.05),0 1px 3px rgba(28,33,51,0.06);--shadow-md:0 4px 6px -1px rgba(28,33,51,0.08),0 2px 4px -2px rgba(28,33,51,0.06);--shadow-lg:0 10px 15px -3px rgba(28,33,51,0.08),0 4px 6px -4px rgba(28,33,51,0.06);--shadow-focus:0 0 0 2px var(--white),0 0 0 4px var(--dufeu-blue);--row-h:44px;--row-pad-y:10px}*{box-sizing:border-box}#root,body,html{margin:0;padding:0;height:100%}body{font-family:var(--font-body);background:var(--off-white);color:var(--grey-dark);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;border:0;background:transparent;padding:0}[tabindex]:focus,button:focus,input:focus,textarea:focus{outline:none}button:focus-visible,input:focus-visible{box-shadow:0 0 0 2px var(--white),0 0 0 3px var(--dufeu-blue)}.app-shell{display:flex;flex-direction:column;min-height:100vh}.font-heading{font-family:var(--font-heading)}.font-body{font-family:var(--font-body)}.topbar{display:flex;align-items:center;gap:16px;height:56px;padding:0 24px;background:var(--white);border-bottom:1px solid var(--grey-light);position:-webkit-sticky;position:sticky;top:0;z-index:30}.topbar-logo{height:22px;display:block}.topbar-divider{width:1px;height:24px;background:var(--grey-light)}.topbar-app-name{font-family:var(--font-heading);font-weight:600;font-size:14px;color:var(--dufeu-indigo);letter-spacing:-.01em}.topbar-spacer{flex:1 1}.topbar-user{display:flex;align-items:center;gap:10px;padding:6px 10px;border-radius:6px}.topbar-user:hover{background:var(--off-white)}.topbar-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-dufeu);color:var(--white);font-family:var(--font-heading);font-weight:600;font-size:12px;display:inline-flex;align-items:center;justify-content:center}.topbar-tabs{display:flex;align-items:center;gap:2px}.topbar-tab{font-family:var(--font-heading);font-weight:500;font-size:13px;height:32px;padding:0 12px;border-radius:6px;color:var(--grey-medium);display:inline-flex;align-items:center;gap:6px;text-decoration:none}.topbar-tab.active,.topbar-tab:hover{background:var(--off-white);color:var(--dufeu-indigo)}.topbar-tab.active{font-weight:600}.page{flex:1 1;padding:24px 32px 64px;max-width:1440px;width:100%;margin:0 auto}.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:20px}.eyebrow{font-size:11px;font-weight:600;color:var(--grey-medium);text-transform:uppercase;letter-spacing:.08em}.eyebrow,.page-title{font-family:var(--font-heading)}.page-title{font-size:24px;font-weight:700;color:var(--dufeu-indigo);margin:4px 0 0;letter-spacing:-.01em}.page-subtitle{color:var(--grey-medium);font-size:13px;margin-top:4px}.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-heading);font-weight:600;font-size:13px;height:36px;padding:0 14px;border-radius:6px;transition:background-color .15s,color .15s,border-color .15s,box-shadow .15s;border:1px solid transparent;white-space:nowrap}.btn-sm{height:30px;padding:0 10px;font-size:12px}.btn-lg{height:44px;padding:0 18px;font-size:14px}.btn-primary{background:var(--dufeu-blue);color:var(--white)}.btn-primary:hover{background:var(--dufeu-blue-hover)}.btn-success{background:var(--dufeu-green);color:var(--dufeu-indigo)}.btn-success:hover{background:var(--dufeu-green-hover)}.btn-gradient{background:var(--gradient-dufeu);color:var(--white)}.btn-gradient:hover{opacity:.92}.btn-ghost{background:var(--white);color:var(--grey-dark);border-color:var(--grey-light)}.btn-ghost:hover{background:var(--off-white)}.btn-quiet{background:transparent;color:var(--grey-dark)}.btn-quiet:hover{background:var(--off-white)}.btn-disabled,.btn:disabled{background:var(--off-white);color:var(--grey-medium);cursor:not-allowed;border-color:var(--grey-light)}.btn .icon{width:14px;height:14px}.card{background:var(--white);border:1px solid var(--grey-light);border-radius:8px;box-shadow:var(--shadow-sm)}.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-heading);font-weight:600;font-size:11px;padding:3px 10px;border-radius:9999px;letter-spacing:.02em}.pill.soft.draft{background:rgba(100,119,186,.12);color:var(--dufeu-iris)}.pill.soft.awaiting{background:rgba(108,172,228,.18);color:var(--dufeu-teal)}.pill.soft.changes{background:#fffbeb;color:#b45309}.pill.soft.confirmed{background:rgba(150,212,4,.18);color:#5a8003}.pill.soft.active{background:rgba(28,33,51,.08);color:var(--dufeu-indigo)}.pill.outline.draft{border:1px solid var(--dufeu-iris);color:var(--dufeu-iris)}.pill.outline.awaiting{border:1px solid var(--dufeu-teal);color:var(--dufeu-teal)}.pill.outline.changes{border:1px solid #b45309;color:#b45309}.pill.outline.confirmed{border:1px solid #5a8003;color:#5a8003}.pill.outline.active{border:1px solid var(--dufeu-indigo);color:var(--dufeu-indigo)}.pill.solid.draft{background:var(--dufeu-iris);color:var(--white)}.pill.solid.awaiting{background:var(--dufeu-teal);color:var(--white)}.pill.solid.changes{background:#b45309;color:var(--white)}.pill.solid.confirmed{background:var(--dufeu-green);color:var(--dufeu-indigo)}.pill.solid.active{background:var(--dufeu-indigo);color:var(--white)}.pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}[data-density=comfortable]{--row-h:48px;--row-pad-y:12px}[data-density=compact]{--row-h:36px;--row-pad-y:6px}.input{height:36px;padding:0 12px;border-radius:6px;border:1px solid var(--grey-light);background:var(--white);width:100%;font-size:14px;color:var(--dufeu-indigo)}.input:focus{box-shadow:var(--shadow-focus);border-color:var(--dufeu-blue)}textarea.input{padding:10px 12px;height:auto;resize:vertical}.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.tbl th{font-family:var(--font-heading);font-size:11px;font-weight:600;color:var(--grey-medium);text-transform:uppercase;letter-spacing:.06em;text-align:left;padding:0 14px;height:36px;background:var(--off-white);border-bottom:1px solid var(--grey-light);position:-webkit-sticky;position:sticky;top:0}.tbl td{height:var(--row-h);padding:var(--row-pad-y) 14px;border-bottom:1px solid rgba(190,190,191,.6);vertical-align:middle}.tbl tr:last-child td{border-bottom:0}.flex,.row{display:flex}.row{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.muted{color:var(--grey-medium)}.indigo{color:var(--dufeu-indigo)}.heading{font-family:var(--font-heading)}.mono{font-feature-settings:"tnum" 1,"lnum" 1,"tnum";font-variant-numeric:tabular-nums}.hr-bar{height:3px;border-radius:3px;background:var(--gradient-bar)}.phase-row{font-family:var(--font-heading)}.phase-row[data-style=bar] td{background:linear-gradient(90deg,rgba(108,172,228,.12),rgba(150,212,4,.06));border-top:2px solid var(--dufeu-blue)}.phase-row[data-style=bar] .phase-name{color:var(--dufeu-indigo);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.08em}.phase-row[data-style=tinted] td{background:var(--off-white)}.phase-row[data-style=tinted] .phase-name{color:var(--dufeu-indigo);font-weight:700}.phase-row[data-style=indigo] td{background:var(--dufeu-indigo);color:var(--white)}.phase-row[data-style=indigo] .phase-name{color:var(--white);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:11px}.phase-row[data-style=indigo] .phase-num{color:rgba(255,255,255,.5)}.phase-row[data-style=bar] .phase-num,.phase-row[data-style=tinted] .phase-num{color:var(--grey-medium);font-weight:600}.drag-handle{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;color:var(--grey-light);cursor:-webkit-grab;cursor:grab;opacity:0;transition:opacity .15s}tr:hover .drag-handle{opacity:1}.drag-handle:active{cursor:-webkit-grabbing;cursor:grabbing;color:var(--dufeu-blue)}.impact{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;font-family:var(--font-heading)}.impact .dot{width:8px;height:8px;border-radius:50%}.impact.none .dot{background:var(--grey-light)}.impact.low .dot{background:var(--dufeu-green)}.impact.medium .dot{background:#f59e0b}.impact.high .dot{background:#dc2626}.conflict{background:#fef2f2!important}.conflict-pill{background:#fef2f2;color:#b91c1c;padding:2px 8px;border-radius:9999px;font-size:11px;font-weight:700;font-family:var(--font-heading);display:inline-flex;align-items:center;gap:4px}.comment-row{background:#fffbeb!important}.comment-bubble{background:#fffbeb;border-left:3px solid #b45309;padding:10px 12px;border-radius:0 6px 6px 0;font-size:13px}.comment-bubble strong{color:var(--dufeu-indigo);font-family:var(--font-heading);font-size:12px}.comment-meta{font-size:11px;color:var(--grey-medium);margin-top:4px}.timeline-grid{display:grid;grid-gap:1px;gap:1px;background:var(--grey-light);border:1px solid var(--grey-light);border-radius:8px;overflow:hidden}.timeline-cell{background:var(--white);padding:4px 8px;min-height:36px;font-size:11px;color:var(--grey-medium)}.timeline-cell.weekend{background:var(--off-white)}.timeline-cell.head{color:var(--dufeu-indigo);border-bottom:1px solid var(--grey-light)}.timeline-bar,.timeline-cell.head{font-family:var(--font-heading);font-weight:600}.timeline-bar{position:absolute;top:8px;height:22px;border-radius:4px;background:var(--dufeu-blue);color:var(--white);font-size:11px;display:flex;align-items:center;padding:0 8px;box-shadow:var(--shadow-sm)}.timeline-bar.green{background:var(--dufeu-green);color:var(--dufeu-indigo)}.timeline-bar.teal{background:var(--dufeu-teal)}.timeline-bar.iris{background:var(--dufeu-iris)}.timeline-bar.conflict{background:#dc2626}.portal-hero{background:var(--gradient-dufeu-full);color:var(--white);padding:64px 48px 56px;border-radius:16px;position:relative;overflow:hidden}.portal-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 90% -10%,rgba(255,255,255,.18),transparent 60%),radial-gradient(600px 300px at 10% 110%,rgba(28,33,51,.18),transparent 60%);pointer-events:none}.backdrop{position:fixed;inset:0;background:rgba(28,33,51,.4);display:flex;align-items:center;justify-content:center;z-index:60;animation:fade .2s ease both}.dialog{background:var(--white);border-radius:12px;box-shadow:var(--shadow-lg);width:560px;max-width:92vw;padding:28px;animation:pop .22s ease both}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:70}.toast{background:var(--dufeu-indigo);color:var(--white);padding:12px 16px;border-radius:8px;box-shadow:var(--shadow-lg);font-size:13px;display:flex;align-items:center;gap:10px;animation:slide .3s ease both}@keyframes slide{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}.cap-bar{display:inline-flex;gap:1px;height:14px;align-items:flex-end}.cap-bar span{display:inline-block;width:4px;background:var(--dufeu-blue);border-radius:1px}.cap-bar span.full{background:#dc2626}.cap-bar span.empty{background:var(--grey-light)}.grid{display:grid}.grid-gap-2{gap:8px}.grid-gap-3{gap:12px}.grid-gap-4{gap:16px}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-cols-5{grid-template-columns:repeat(5,1fr)}.grid-autofill-220{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.grid-autofill-280{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.scroll-x{overflow-x:auto;-webkit-overflow-scrolling:touch}.scroll-x>*{min-width:100%}@media (max-width:768px){.page{padding:16px}.page-header{flex-direction:column;align-items:stretch;gap:16px}.page-title{font-size:20px}.topbar{padding:0 12px;gap:8px;overflow-x:auto}.topbar-tabs{overflow-x:auto;flex-shrink:0}.topbar-app-name,.topbar-divider,.topbar-spacer{display:none}.topbar-user{padding:4px 6px;gap:6px}.topbar-user>div:not(.topbar-avatar){display:none}.grid-cols-2,.grid-cols-3,.grid-cols-4,.grid-cols-5{grid-template-columns:1fr}.card[data-density]{overflow-x:auto!important;-webkit-overflow-scrolling:touch}.card[data-density] .tbl{min-width:720px}.scroll-x-md{overflow-x:auto;-webkit-overflow-scrolling:touch}.dialog{padding:20px;border-radius:10px}.portal-hero{padding:32px 20px 28px;border-radius:12px}.portal-hero h1{font-size:28px!important;line-height:1.1}.portal-hero p{font-size:14px!important}.toast-stack{left:16px;right:16px;bottom:16px}.toast{font-size:12px}}@media (min-width:769px) and (max-width:1024px){.grid-cols-4,.grid-cols-5{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:1fr}}