@import "https://fonts.googleapis.com/css2?family=Instrument+Sans:wght@400;500;600;700&family=DM+Mono:wght@400;500&display=swap";*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:JetBrains Mono,Fira Code,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.collapse{visibility:collapse}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.mb-1{margin-bottom:.25rem}.ml-auto{margin-left:auto}.mt-1{margin-top:.25rem}.block{display:block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.flex-shrink{flex-shrink:1}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.text-center{text-align:center}.text-sm{font-size:.875rem;line-height:1.25rem}.uppercase{text-transform:uppercase}.italic{font-style:italic}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.invert{--tw-invert:invert(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--bg:#f8f8f8;--bg-elevated:#fff;--bg-card:#fff;--bg-card-hover:#fafafa;--bg-sidebar:#111;--bg-sidebar-hover:#ffffff0f;--bg-input:#f2f2f2;--bg-surface:#fafafa;--border:#e8e8e8;--border-strong:#d4d4d4;--border-accent:#111;--text:#111;--text-dim:#6b6b6b;--text-muted:#999;--brand:#111;--brand-hover:#333;--brand-dim:#1111110a;--brand-light:#11111114;--brand-yellow:gold;--brand-yellow-hover:#e6c200;--accent:#111;--accent-hover:#333;--accent-light:#f2f2f2;--accent-dim:#1111110a;--green:#16a34a;--green-light:#f0fdf4;--yellow:#ca8a04;--yellow-light:#fefce8;--red:#dc2626;--red-light:#fef2f2;--blue:#2563eb;--blue-light:#eff6ff;--orange:#ea580c;--orange-light:#fff7ed;--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000000f;--shadow-lg:0 12px 32px #00000014;--transition:.15s ease;--font:"Instrument Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"DM Mono", "SF Mono", "Fira Code", monospace}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}a{color:var(--accent);font-weight:500;text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.3s cubic-bezier(.4,0,.2,1) fadeIn}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.build-pulse{animation:1.5s infinite pulse}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.app{background:var(--bg);min-height:100vh}.main{min-height:calc(100vh - 56px)}.page-content{max-width:1200px;margin:0 auto;padding:1.75rem 2.5rem}.project-bar{border-bottom:2px solid var(--accent);z-index:99;background:#fff;position:sticky;top:56px}.project-bar-inner{align-items:center;gap:.5rem;max-width:1400px;margin:0 auto;padding:.55rem 2rem;font-size:.85rem;display:flex}.project-bar-label{color:var(--text-muted);font-weight:400}.project-bar-sep{color:var(--border-strong)}.project-bar-name{color:var(--text);font-weight:600}.project-bar-stage{color:var(--text-muted);margin-left:auto;font-size:.78rem}.topnav{z-index:100;background:gold;border-bottom:none;height:56px;position:sticky;top:0}.topnav-inner{justify-content:space-between;align-items:center;max-width:1400px;height:100%;margin:0 auto;padding:0 2rem;display:flex}.topnav-left{align-items:center;gap:2rem;display:flex}.topnav-right{align-items:center;gap:1rem;display:flex}.logo{cursor:pointer;flex-shrink:0;align-items:center;gap:.55rem;display:flex}.logo-icon{color:#111;flex-shrink:0;width:24px;height:24px}.logo-text{color:#111;letter-spacing:-.02em;font-size:.88rem;font-weight:700}.logo-text span{color:#111;font-weight:700}.nav-links{align-items:center;gap:.25rem;display:flex}.nav-links button{color:#00000080;cursor:pointer;font-size:.875rem;font-weight:450;font-family:var(--font);white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:.4rem .75rem;transition:all .12s}.nav-links button:hover{color:#111;background:#00000014}.nav-links button.active{color:#111;background:#0000001a;font-weight:600}.user-block{align-items:center;gap:.5rem;display:flex}.avatar{color:gold;background:#111;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;font-size:.6rem;font-weight:600;display:flex}.user-name{color:#111;font-size:.85rem;font-weight:500}.logout-btn{color:#0006;cursor:pointer;background:0 0;border:none;border-radius:7px;justify-content:center;align-items:center;padding:.35rem;transition:all .12s;display:flex}.logout-btn:hover{color:#111;background:#0000001a}.role-pill{cursor:pointer;-webkit-user-select:none;user-select:none;background:#00000014;border:1px solid #0000001a;border-radius:7px;flex-shrink:0;padding:2px;display:flex;position:relative}.role-pill-bg{background:#111;border-radius:5px;width:calc(50% - 2px);height:calc(100% - 4px);transition:transform .2s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;left:2px}.role-pill-bg.right{transform:translate(100%)}.role-pill-option{z-index:1;color:#0006;white-space:nowrap;padding:.2rem .5rem;font-size:.62rem;font-weight:600;transition:color .15s;position:relative}.role-pill-option.active{color:gold}.btn{cursor:pointer;font-size:.875rem;font-weight:500;font-family:var(--font);letter-spacing:-.01em;border:none;border-radius:7px;align-items:center;gap:.45rem;padding:.5rem 1rem;transition:all .12s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff;font-weight:600;box-shadow:0 1px 2px #0000001f}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 2px 8px #0000001f}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-strong)}.btn-success{background:var(--green);color:#fff;font-weight:600}.btn-success:hover{background:#15803d}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:.35rem .65rem;font-size:.8rem}.btn-lg{padding:.6rem 1.15rem;font-size:.92rem}.btn-ghost{color:var(--text-dim);background:0 0;padding:.35rem .6rem}.btn-ghost:hover{background:var(--bg-input);color:var(--text)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:.75rem;margin-bottom:1.75rem;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.15rem;transition:all .12s}.stat-card:hover{box-shadow:var(--shadow)}.stat-card .stat-icon{border-radius:8px;justify-content:center;align-items:center;width:34px;height:34px;margin-bottom:.65rem;font-size:.9rem;display:flex}.stat-card .stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.2rem;font-size:.75rem;font-weight:500}.stat-card .stat-value{letter-spacing:-.02em;font-size:1.5rem;font-weight:700}.project-layout{grid-template-columns:1fr 320px;gap:1.25rem;display:grid}.project-main{min-width:0}.project-sidebar{flex-direction:column;gap:1rem;display:flex}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{text-align:left;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--bg-surface);padding:.6rem .85rem;font-size:.7rem;font-weight:600}thead th:first-child{border-radius:var(--radius) 0 0 0}thead th:last-child{border-radius:0 var(--radius) 0 0}tbody td{border-bottom:1px solid var(--border);padding:.7rem .85rem;font-size:.875rem}tbody tr{transition:all .1s}tbody tr:hover{background:var(--bg-surface)}.req-tag{background:var(--yellow-light);color:var(--yellow);border-radius:5px;align-items:center;gap:.3rem;margin:.1rem;padding:.2rem .55rem;font-size:.75rem;font-weight:600;display:inline-flex}.editor-preview h1{color:var(--text);margin:.75rem 0 .5rem;font-size:1.3rem;font-weight:700}.editor-preview h2{color:var(--text);margin:1rem 0 .4rem;font-size:1.05rem;font-weight:600}.editor-preview h3{color:var(--text);margin:.75rem 0 .35rem;font-size:.9rem;font-weight:600}.editor-preview p{color:var(--text-dim);margin-bottom:.6rem;font-size:.9rem;line-height:1.7}.editor-preview ul,.editor-preview ol{color:var(--text-dim);margin:.4rem 0 .6rem 1.5rem;font-size:.9rem}.editor-preview li{margin-bottom:.25rem;list-style:outside}.editor-preview strong{color:var(--text)}.transcript-panel{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);max-height:400px;padding:1.15rem;overflow-y:auto}.transcript-line{color:var(--text-dim);border-bottom:1px solid var(--border);padding:.4rem 0;font-size:.8rem;line-height:1.6}.transcript-line:last-child{border-bottom:none}.transcript-line .speaker{color:var(--text);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.transcript-line.requirement{background:var(--yellow-light);border-bottom:none;border-radius:6px;margin:.25rem -.5rem;padding:.4rem .5rem}.feedback-thread{flex-direction:column;gap:.75rem;display:flex}.feedback-msg{border-radius:var(--radius-lg);max-width:85%;padding:.8rem 1rem;font-size:.9rem;line-height:1.6}.feedback-msg.client{background:var(--blue-light);color:var(--text);border-bottom-left-radius:4px;align-self:flex-start}.feedback-msg.owner{background:var(--bg-surface);color:var(--text);border:1px solid var(--border);border-bottom-right-radius:4px;align-self:flex-end}.feedback-msg .msg-meta{color:var(--text-muted);margin-bottom:.2rem;font-size:.75rem;font-weight:500}.messages-list{flex-direction:column;gap:.6rem;max-height:350px;margin-bottom:1rem;padding:.5rem 0;display:flex;overflow-y:auto}.message{max-width:80%}.message .msg-header{margin-bottom:.2rem;font-size:.75rem}.message .msg-author{color:var(--text-dim);font-weight:600}.message .msg-time{color:var(--text-muted);margin-left:.5rem}.message .msg-body{color:var(--text);background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);border-bottom-left-radius:4px;padding:.6rem .8rem;font-size:.9rem;line-height:1.5}.message.sent{text-align:right;align-self:flex-end}.message.sent .msg-body{background:var(--accent);color:#fff;border-color:var(--accent);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:4px}.message-input{gap:.5rem;display:flex}.message-input input{background:var(--bg-input);border:1px solid var(--border);font-size:.875rem;font-family:var(--font);color:var(--text);border-radius:7px;outline:none;flex:1;padding:.55rem .8rem}.message-input input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #1111110a}.cta-banner{background:var(--accent);color:#fff;border-radius:var(--radius-xl);text-align:center;padding:2rem}.cta-banner h3{margin-bottom:.4rem;font-size:1.2rem;font-weight:700}.cta-banner p{opacity:.75;margin-bottom:1.25rem;font-size:.85rem}.cta-banner .btn,.cta-banner .cta-btn{color:var(--accent);background:#fff;font-weight:600}.cta-banner .btn:hover,.cta-banner .cta-btn:hover{background:#ffffffe6}.client-hero{text-align:center;padding:2rem 1rem 1.25rem}.client-hero h2{letter-spacing:-.02em;margin-bottom:.3rem;font-size:1.4rem;font-weight:700}.client-hero p{color:var(--text-dim);font-size:.88rem}.client-card-center{max-width:640px;margin:0 auto 1.5rem}.progress-bar{background:var(--bg-input);border-radius:3px;width:100%;height:6px;margin:1rem 0;overflow:hidden}.progress-bar-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .5s}.upcoming-actions{list-style:none}.upcoming-actions li{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;padding:.6rem 0;font-size:.9rem;display:flex}.upcoming-actions li:last-child{border-bottom:none}.action-dot{background:var(--accent);border-radius:50%;flex-shrink:0;width:6px;height:6px}.proposal-preview{background:var(--bg-surface);color:var(--text-dim);border:1px solid var(--border);border-radius:7px;padding:1.15rem;font-size:.9rem;line-height:1.8}.proposal-preview h4{color:var(--text);margin-bottom:.5rem;font-size:.95rem}.proposal-preview p{margin-bottom:.5rem}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;margin-top:.75rem;display:grid}.calendar-header{color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.05em;padding:.3rem;font-size:.62rem;font-weight:600}.calendar-day{text-align:center;cursor:pointer;font-size:.78rem;font-family:var(--font-mono);border:1px solid #0000;border-radius:6px;padding:.45rem .2rem;transition:all .1s}.calendar-day:hover{background:var(--bg-surface)}.calendar-day.disabled{color:var(--text-muted);cursor:default;opacity:.3}.calendar-day.disabled:hover{background:0 0}.calendar-day.monday{border-color:var(--accent);background:var(--accent-dim);font-weight:600}.calendar-day.selected{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700}.calendar-day.today{border-color:var(--green)}.time-slots{flex-direction:column;gap:.35rem;margin-top:.75rem;display:flex}.time-slot{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;border-radius:7px;justify-content:space-between;align-items:center;padding:.75rem .9rem;transition:all .1s;display:flex}.time-slot:hover{border-color:var(--border-strong);background:var(--bg-surface)}.time-slot.selected{border-color:var(--accent);background:var(--accent-dim)}.time-slot .slot-day{font-size:.9rem;font-weight:600}.time-slot .slot-time{color:var(--text-dim);font-size:.75rem}.time-slot .slot-check{border:1.5px solid var(--border-strong);color:#0000;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.55rem;transition:all .1s;display:flex}.time-slot.selected .slot-check{background:var(--accent);border-color:var(--accent);color:#fff}.activity-item{border-bottom:1px solid var(--border);gap:.75rem;padding:.7rem 0;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.7rem;display:flex}.activity-item .activity-text{color:var(--text-dim);font-size:.9rem;line-height:1.5}.activity-item .activity-text strong{color:var(--text);font-weight:600}.activity-item .activity-time{color:var(--text-muted);margin-top:.1rem;font-size:.7rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:300;background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:90%;max-width:480px;box-shadow:var(--shadow-lg);padding:1.5rem}.toast-container{z-index:400;position:fixed;top:72px;right:2rem}input,textarea,select{font-family:var(--font);background:var(--bg-input);border:1px solid var(--border);color:var(--text);border-radius:7px;outline:none;padding:.55rem .8rem;font-size:.875rem;transition:all .12s}input:focus,textarea:focus,select:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px #1111110a}textarea{resize:vertical}input::-moz-placeholder{color:var(--text-muted)}textarea::-moz-placeholder{color:var(--text-muted)}input::placeholder,textarea::placeholder{color:var(--text-muted)}@media (width<=1024px){.project-layout{grid-template-columns:1fr}}@media (width<=768px){.nav-links,.user-name{display:none}.page-content{padding:1.25rem 1rem}}
