@import"https://fonts.googleapis.com/css2?family=Manrope:wght@500;600;700;800&display=swap";:root{--color-brand: #3157d5;--color-brand-2: #0f9f8f;--color-brand-light: #eef3ff;--color-success: #0f8a6a;--color-success-light: #e8f7f1;--color-warning: #a96207;--color-warning-light: #fff6df;--color-danger: #c0332b;--color-danger-light: #fff0ee;--color-neutral-950: #111827;--color-neutral-900: #18212f;--color-neutral-800: #1f2937;--color-neutral-700: #394254;--color-neutral-600: #667085;--color-neutral-300: #d6dbe6;--color-neutral-200: #e6e9f0;--color-neutral-100: #f2f4f7;--color-neutral-50: #f8fafc;--color-white: #ffffff;--shadow-card: 0 18px 42px rgba(17, 24, 39, .08);--shadow-soft: 0 10px 24px rgba(17, 24, 39, .06);font-family:Manrope,Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--color-neutral-950);background:var(--color-neutral-50)}*{box-sizing:border-box}body{margin:0;min-width:320px;background:linear-gradient(180deg,#fbfcff,#f3f6fb 45%,#eef2f7)}button,input,textarea{font:inherit}.app{min-height:100vh}.login-page{display:grid;min-height:100vh;place-items:center;padding:24px;background:linear-gradient(#111827b8,#1118278a),url(https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?auto=format&fit=crop&w=1800&q=80) center / cover}.login-panel{width:min(100%,460px);padding:30px;border:1px solid rgba(255,255,255,.42);border-radius:8px;background:#fffffff5;box-shadow:0 22px 60px #00000042}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:30px}.login-mark{display:grid;place-items:center;width:48px;height:48px;border-radius:8px;color:#fff;background:var(--color-brand)}.login-brand span{color:var(--color-brand);font-size:24px;font-weight:800}.login-brand p,.login-copy p{margin:0;color:var(--color-neutral-600)}.login-copy{margin-bottom:24px}.login-copy h1{margin:8px 0 10px;font-size:30px;line-height:1.12;letter-spacing:0}.login-copy .eyebrow{color:var(--color-brand)}.login-form{display:grid;gap:14px}.login-form label{display:grid;gap:7px;color:var(--color-neutral-600);font-size:13px;font-weight:800}.login-form input{width:100%;border:1px solid var(--color-neutral-200);border-radius:8px;padding:12px 13px;color:var(--color-neutral-950);background:#fff}.login-form input:focus{border-color:var(--color-brand);outline:3px solid var(--color-brand-light)}.login-error{padding:10px 12px;border:1px solid var(--color-danger);border-radius:8px;color:var(--color-danger);background:var(--color-danger-light);font-size:13px;font-weight:800}.login-success{padding:10px 12px;border:1px solid var(--color-success);border-radius:8px;color:var(--color-success);background:var(--color-success-light);font-size:13px;font-weight:800}.login-submit{width:100%;margin-top:4px}.login-help{width:100%;border:0;padding:4px 0;color:var(--color-brand);background:transparent;cursor:pointer;font-size:13px;font-weight:800}.auth-status h1{margin:0 0 10px;font-size:28px;line-height:1.15;letter-spacing:0}.auth-status>p{margin:0;color:var(--color-neutral-600);line-height:1.55}button:disabled{cursor:not-allowed;opacity:.62}.header{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;min-height:68px;padding:0 32px;border-bottom:1px solid var(--color-neutral-200);background:#ffffffe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.brand,.section-title,.title-inline,.header-actions,.unit-line,.metric-row,.handover-alert,.checklist div{display:flex;align-items:center}.brand{gap:8px;color:var(--color-brand);font-size:21px;font-weight:800}.segment{display:flex;gap:4px;padding:4px;border:1px solid var(--color-neutral-200);border-radius:10px;background:var(--color-white)}.segment button,.icon-button,.avatar,.secondary-action,.primary{cursor:pointer;border:0}.segment button{padding:8px 14px;border-radius:8px;color:var(--color-neutral-600);background:transparent;font-weight:700}.segment button.active{color:var(--color-white);background:var(--color-brand)}.header-actions{position:relative;gap:10px}.icon-button,.avatar{display:grid;place-items:center;width:38px;height:38px;border-radius:8px;color:var(--color-brand);background:var(--color-brand-light);transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease}.icon-button:hover,.avatar:hover{background:#dbeaf2;transform:translateY(-1px)}.icon-button{position:relative}.avatar.active{outline:3px solid rgba(27,79,138,.16)}.profile-trigger{display:grid;grid-template-columns:18px minmax(0,1fr);gap:9px;width:auto;min-width:178px;height:42px;padding:6px 10px;border:1px solid var(--color-neutral-200);color:var(--color-neutral-950);background:var(--color-white);text-align:left}.profile-trigger>span,.profile-trigger strong,.profile-trigger small{display:block;min-width:0}.profile-trigger strong,.profile-trigger small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-trigger strong{font-size:13px;line-height:1.1}.profile-trigger small{margin-top:2px;color:var(--color-neutral-600);font-size:11px;font-weight:800}.profile-menu{position:relative}.profile-popover{position:absolute;top:calc(100% + 12px);right:0;z-index:20;width:250px;padding:10px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white);box-shadow:0 18px 45px #11182729}.notifications-popover{position:absolute;top:calc(100% + 12px);right:94px;z-index:21;width:min(420px,calc(100vw - 32px));max-height:360px;overflow:auto;padding:10px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white);box-shadow:0 18px 45px #11182729}.notifications-popover:before{position:absolute;top:-6px;right:102px;width:12px;height:12px;border-left:1px solid var(--color-neutral-200);border-top:1px solid var(--color-neutral-200);background:var(--color-white);content:"";transform:rotate(45deg)}.notifications-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;padding:8px 10px 10px;border-bottom:1px solid var(--color-neutral-200)}.notifications-header strong{font-size:14px}.notifications-header span{color:var(--color-neutral-600);font-size:12px;font-weight:700}.notifications-list{display:grid;gap:8px}.notification-item{display:grid;gap:4px;padding:10px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-neutral-50)}.notification-item p{margin:0;color:var(--color-neutral-900);font-size:13px;line-height:1.4}.notification-item time{color:var(--color-neutral-600);font-size:12px;font-weight:700}.notification-empty{padding:18px 12px;color:var(--color-neutral-600);font-size:13px;text-align:center}.notification-error{color:var(--color-danger)}.profile-popover:before{position:absolute;top:-6px;right:17px;width:12px;height:12px;border-left:1px solid var(--color-neutral-200);border-top:1px solid var(--color-neutral-200);background:var(--color-white);content:"";transform:rotate(45deg)}.profile-summary{padding:8px 10px 12px;border-bottom:1px solid var(--color-neutral-200)}.profile-summary strong,.profile-summary span{display:block}.profile-summary span{margin-top:3px;color:var(--color-neutral-600);font-size:12px;font-weight:700}.profile-popover button{display:grid;grid-template-columns:20px 1fr 18px;align-items:center;gap:10px;width:100%;min-height:56px;margin-top:8px;border:1px solid transparent;border-radius:8px;padding:9px 10px;color:var(--color-neutral-950);background:transparent;cursor:pointer;text-align:left}.profile-popover button:hover,.profile-popover button.selected{border-color:var(--color-brand-light);background:var(--color-brand-light)}.profile-popover button.selected{color:var(--color-brand)}.profile-popover button span,.profile-popover button small{display:block}.profile-popover button small{margin-top:2px;color:var(--color-neutral-600);font-size:12px;font-weight:700}.icon-button span{position:absolute;top:-6px;right:-5px;display:grid;place-items:center;min-width:18px;height:18px;border-radius:999px;color:#fff;background:var(--color-danger);font-size:11px;font-weight:800}.shell{max-width:1440px;margin:0 auto;padding:26px 24px 56px}.app-shell{display:grid;grid-template-columns:238px minmax(0,1fr);align-items:start;gap:22px}.workspace{min-width:0}.side-nav{position:sticky;top:92px;display:grid;gap:14px;padding:16px;border:1px solid var(--color-neutral-200);border-radius:8px;background:#fffffff5;box-shadow:var(--shadow-card)}.side-nav-header{padding-bottom:14px;border-bottom:1px solid var(--color-neutral-200)}.side-nav-header span,.side-nav-header strong{display:block}.side-nav-header span{color:var(--color-neutral-600);font-size:12px;font-weight:900;text-transform:uppercase}.side-nav-header strong{margin-top:5px;color:var(--color-neutral-950);font-size:15px;line-height:1.25}.side-nav nav{display:grid;gap:8px}.side-nav button{display:grid;grid-template-columns:20px minmax(0,1fr);align-items:center;gap:10px;min-height:44px;border:1px solid transparent;border-radius:8px;padding:10px 11px;color:var(--color-neutral-700);background:transparent;cursor:pointer;font-weight:900;text-align:left}.side-nav button:hover,.side-nav button.active{border-color:#3157d529;color:var(--color-brand);background:var(--color-brand-light)}.side-nav button span{min-width:0;overflow-wrap:anywhere}.hero{display:grid;grid-template-columns:minmax(0,1fr) 420px;align-items:center;justify-content:space-between;gap:24px;min-height:230px;padding:34px;border-radius:8px;color:#fff;background:linear-gradient(135deg,#1f2937e0,#3157d5c2),url(https://images.unsplash.com/photo-1494526585095-c41746248156?auto=format&fit=crop&w=1800&q=80) center / cover;box-shadow:0 24px 55px #1118272e;overflow:hidden;position:relative}.hero:after{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#0918272e,#09182700);content:"";pointer-events:none}.hero-content,.hero-summary{position:relative;z-index:1}.hero h1{max-width:680px;margin:6px 0 10px;font-size:40px;line-height:1.04;letter-spacing:0}.hero p{margin:0 0 16px;opacity:.9}.eyebrow{text-transform:uppercase;font-size:12px;font-weight:800;letter-spacing:0}.hero-pill{display:inline-flex;max-width:100%;padding:7px 12px;border-radius:999px;background:#ffffff29;font-size:13px;font-weight:800;overflow-wrap:anywhere}.hero-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.developer-hero{grid-template-columns:1fr;min-height:190px}.hero-summary div{min-height:112px;padding:16px;border:1px solid rgba(255,255,255,.26);border-radius:8px;background:#ffffff26;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.hero-summary span,.unit-hero span,.timeline-caption{color:var(--color-neutral-600);font-size:12px;font-weight:800;text-transform:uppercase}.hero-summary span{color:#ffffffbd}.hero-summary strong{display:block;margin-top:12px;color:#fff;font-size:28px;line-height:1}.toast{position:fixed;top:84px;right:24px;z-index:50;width:fit-content;max-width:min(360px,calc(100vw - 48px));padding:12px 16px;border:1px solid rgba(20,121,92,.22);border-radius:10px;color:var(--color-success);background:var(--color-success-light);box-shadow:0 18px 45px #11182724;font-size:14px;font-weight:800}.inline-error{margin-bottom:14px;padding:10px 12px;border:1px solid var(--color-danger);border-radius:8px;color:var(--color-danger);background:var(--color-danger-light);font-size:13px;font-weight:800}.inline-status{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;padding:10px 12px;border:1px solid var(--color-brand-light);border-radius:8px;color:var(--color-brand);background:var(--color-brand-light);font-size:13px;font-weight:800}.skeleton-card,.skeleton-list{overflow:hidden}.skeleton-list{display:grid;gap:12px}.skeleton-line,.skeleton-pill,.skeleton-dot,.skeleton-media{position:relative;overflow:hidden;background:linear-gradient(90deg,var(--color-neutral-100),#e9edf5,var(--color-neutral-100));background-size:220% 100%;animation:skeleton 1.3s ease-in-out infinite}.skeleton-line{width:100%;height:13px;border-radius:999px}.skeleton-title{width:min(280px,70%);height:18px;margin-bottom:14px}.skeleton-track{width:100%;height:8px;margin-bottom:16px}.skeleton-line.short{width:64%}.skeleton-pill{width:92px;height:24px;border-radius:999px}.skeleton-dot{width:30px;height:30px;border-radius:50%}.skeleton-media{width:112px;height:112px;border-radius:8px}.skeleton-milestone,.skeleton-defect{box-shadow:none}.skeleton-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:22px}.engineer-grid,.developer-grid{align-items:start}.integrations-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.integrations-grid .wide{grid-column:span 3}.buyer-grid{grid-template-columns:1fr}.status-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px}.card{padding:22px;border:1px solid var(--color-neutral-200);border-radius:8px;background:#fffffff5;box-shadow:var(--shadow-card)}.wide{grid-column:span 2}.buyer-grid .wide{grid-column:auto}.accent{border-left:0}.section-title{justify-content:flex-start;gap:8px;margin-bottom:20px}.section-title h2{margin:0;font-size:18px;line-height:1.2}.section-title p{margin:6px 0 0;color:var(--color-neutral-600)}.section-title.split{justify-content:space-between;gap:16px}.title-inline{gap:8px}.timeline{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px;overflow:visible}.timeline-card{position:relative}.timeline-track{height:7px;margin:0 4px 16px;overflow:hidden;border-radius:999px;background:var(--color-neutral-200)}.timeline-track span{display:block;width:64%;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--color-success),var(--color-brand-2))}.timeline-caption{color:var(--color-neutral-600)}.timeline-actions{display:flex;align-items:center;gap:12px}.milestone{display:grid;align-content:start;gap:12px;min-width:0;min-height:148px;padding:15px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white);box-shadow:var(--shadow-soft)}.milestone.success{border-color:#14795c33}.milestone.brand{border-color:#174b7a3d}.milestone.warning{border-color:#b7791f3d}.milestone strong,.milestone small{display:block}.milestone strong{font-size:15px;line-height:1.25}.milestone small{margin:5px 0 9px;color:var(--color-neutral-600)}.milestone .badge{max-width:100%;white-space:normal}.dot{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;color:#fff;font-size:12px;font-weight:900;box-shadow:0 8px 18px #1118271f}.dot.success,.badge.success{background:var(--color-success-light);color:var(--color-success)}.dot.success{background:var(--color-success);color:#fff}.dot.brand{background:var(--color-brand)}.dot.warning{background:var(--color-warning)}.dot.neutral{background:var(--color-neutral-600)}.unit-line,.metric-row{justify-content:space-between;gap:16px}.unit-line{margin:12px 0 20px}.unit-line span,.metric-row span{color:var(--color-neutral-600)}.unit-card,.handover-card{min-height:286px}.unit-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px;border-radius:8px;background:var(--color-brand-light)}.unit-hero strong{display:block;margin-top:4px;color:var(--color-brand);font-size:30px;line-height:1}.progress{height:10px;margin-bottom:18px;overflow:hidden;border-radius:999px;background:var(--color-neutral-200)}.progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--color-brand),var(--color-brand-2))}.metric-row{padding:12px 0;border-top:1px solid var(--color-neutral-200)}.defect-list{display:grid;gap:12px}.buyer-selector-card{margin-top:0}.buyer-select{display:grid;gap:6px;min-width:280px;color:var(--color-neutral-600);font-size:13px;font-weight:800}.buyer-select select{width:100%;border:1px solid var(--color-neutral-200);border-radius:8px;padding:10px 12px;color:var(--color-neutral-950);background:#fff}.buyer-profile-grid{display:grid;grid-template-columns:minmax(240px,1.35fr) repeat(3,minmax(140px,1fr));gap:12px}.buyer-profile-grid>div{min-width:0;padding:14px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-neutral-50)}.buyer-profile-grid span,.buyer-profile-grid strong,.buyer-profile-grid p{display:block}.buyer-profile-grid span{color:var(--color-neutral-600);font-size:12px;font-weight:900;text-transform:uppercase}.buyer-profile-grid strong{margin-top:5px;overflow-wrap:anywhere}.buyer-profile-main{background:var(--color-brand-light)!important}.buyer-profile-main strong{color:var(--color-brand);font-size:24px}.buyer-profile-main p{margin:6px 0 0;color:var(--color-neutral-700)}.buyer-overview-card{background:linear-gradient(180deg,var(--color-white),#f7fbff)}.project-info-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.project-info-grid>div{min-width:0;padding:14px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white)}.project-info-grid span,.project-info-grid strong{display:block}.project-info-grid span{color:var(--color-neutral-600);font-size:12px;font-weight:900;text-transform:uppercase}.project-info-grid strong{margin-top:7px;overflow-wrap:anywhere;color:var(--color-neutral-950);line-height:1.35}.important-dates-card{min-height:286px}.construction-updates-card,.payments-card{background:linear-gradient(180deg,var(--color-white),#f8fbff)}.construction-summary{display:grid;grid-template-columns:minmax(240px,.75fr) minmax(0,1.25fr);gap:18px;align-items:stretch}.construction-percent{display:grid;align-content:start;gap:12px;min-height:100%;padding:18px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white)}.construction-percent strong,.payment-summary strong{display:block;color:var(--color-neutral-950);font-size:32px;line-height:1}.construction-percent small{display:block;color:var(--color-neutral-600);line-height:1.45}.construction-percent span,.payment-summary span,.construction-stage strong,.payment-row span{display:block}.construction-percent span,.payment-summary span,.payment-row span{margin-top:7px;color:var(--color-neutral-600);font-size:12px;font-weight:900;text-transform:uppercase}.construction-stage-list,.payment-schedule{display:grid;gap:12px}.construction-stage-list{padding:6px 0}.construction-stage{display:grid;grid-template-columns:minmax(120px,.75fr) minmax(160px,1.35fr) auto;gap:14px;align-items:center;padding:12px 0;border-bottom:1px solid var(--color-neutral-200)}.construction-stage:last-child,.payment-row:last-child{border-bottom:0}.construction-stage div:first-child{min-width:0}.construction-stage strong{color:var(--color-neutral-950);line-height:1.25}.construction-stage div:first-child span{display:block;margin-top:4px;color:var(--color-neutral-600);font-size:12px;font-weight:800}.stage-progress{height:9px;overflow:hidden;border-radius:999px;background:var(--color-neutral-200)}.overall-progress{height:12px;overflow:hidden;border-radius:999px;background:var(--color-neutral-200)}.stage-progress span,.overall-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--color-brand),var(--color-brand-2))}.payment-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:18px}.payment-summary>div{min-width:0;padding:16px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white)}.payment-summary p{margin:8px 0 0;color:var(--color-neutral-600);font-size:13px;font-weight:800}.payment-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(130px,auto) auto;gap:14px;align-items:center;padding:13px 0;border-bottom:1px solid var(--color-neutral-200)}.payment-row>strong{color:var(--color-neutral-950);white-space:nowrap}.notice-list{display:grid;gap:12px}.notice-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:start;padding:14px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-neutral-50)}.notice-item strong,.notice-item p,.notice-item time{display:block}.notice-item p{margin:6px 0 0;color:var(--color-neutral-600);line-height:1.45}.notice-item time{color:var(--color-neutral-600);font-size:12px;font-weight:900;white-space:nowrap}.compliance-hero-card,.integrations-hero-card{background:linear-gradient(180deg,var(--color-white),#f7fbff)}.compliance-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.compliance-overview>div,.signal-list>div{min-width:0;padding:16px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white)}.compliance-overview span,.signal-list span,.integration-card>span{display:block;color:var(--color-neutral-600);font-size:12px;font-weight:900;text-transform:uppercase}.compliance-overview strong{display:block;margin-top:8px;color:var(--color-neutral-950);font-size:31px;line-height:1}.compliance-overview p,.signal-list p,.compliance-item p,.integration-card p,.integration-intro{margin:8px 0 0;color:var(--color-neutral-600);line-height:1.45}.compliance-list,.signal-list{display:grid;gap:12px}.compliance-item{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:14px;padding:14px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-neutral-50)}.compliance-item strong,.signal-list strong{display:block;color:var(--color-neutral-950);line-height:1.25}.signal-list strong{margin-top:7px}.integration-intro{max-width:760px;margin-top:0}.integration-card{display:grid;align-content:start;gap:12px;min-height:330px}.integration-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}.integration-icon{display:grid;place-items:center;width:148px;height:42px;border-radius:8px;border:1px solid var(--color-neutral-200);background:var(--color-white);box-shadow:0 8px 18px #1118270d}.integration-icon.selldo{width:128px}.integration-icon svg{display:block;width:100%;height:100%}.integration-card h2{margin:0;font-size:20px}.integration-syncs{display:flex;flex-wrap:wrap;gap:8px;margin-top:2px}.integration-syncs span{display:inline-flex;align-items:center;min-height:28px;padding:6px 8px;border-radius:8px;color:var(--color-neutral-700);background:var(--color-neutral-100);font-size:12px;font-weight:800}.integration-sync-status{display:block;margin-top:auto;color:var(--color-neutral-600);font-size:12px;font-weight:800}.defect-toolbar{display:flex;margin:-6px 0 14px}.defect-tabs button{display:inline-flex;align-items:center;gap:7px}.defect-tabs span{display:grid;place-items:center;min-width:20px;height:20px;border-radius:999px;color:inherit;background:var(--color-neutral-100);font-size:12px;font-weight:900}.defect-tabs button.active span{color:var(--color-brand);background:var(--color-white)}.defect-card{display:grid;grid-template-columns:112px 1fr;gap:16px;padding:12px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white);box-shadow:var(--shadow-soft);transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.defect-card:hover{border-color:var(--color-neutral-300);box-shadow:0 16px 34px #1118271a;transform:translateY(-1px)}.defect-media{min-width:0}.empty-state{display:grid;justify-items:center;gap:8px;padding:28px 18px;border:1px dashed var(--color-neutral-200);border-radius:8px;color:var(--color-neutral-600);background:var(--color-neutral-50);text-align:center}.empty-state strong{color:var(--color-neutral-950)}.empty-state p{max-width:360px;margin:0;font-size:13px}.defect-card img{width:112px;height:112px;border-radius:8px;object-fit:cover}.defect-image-placeholder{display:grid;place-items:center;width:112px;height:112px;border:1px dashed var(--color-neutral-200);border-radius:8px;color:var(--color-neutral-600);background:var(--color-white)}.defect-card-body{min-width:0;padding:2px 2px 2px 0}.defect-card p{margin:8px 0 0;color:var(--color-neutral-600);font-size:13px}.defect-top{display:flex;align-items:start;justify-content:space-between;gap:12px}.defect-top small{display:block;margin-bottom:4px;color:var(--color-brand);font-size:12px;font-weight:900}.defect-top strong{display:block;font-size:16px;line-height:1.35;overflow-wrap:anywhere}.defect-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.defect-meta span{display:inline-flex;align-items:center;gap:5px;padding:6px 8px;border-radius:8px;color:var(--color-neutral-700);background:var(--color-neutral-100);font-size:12px;font-weight:800}.defect-assignment{padding-top:8px;border-top:1px solid var(--color-neutral-200)}.resolution{color:var(--color-success)!important;font-weight:700}.defect-actions{display:flex;justify-content:flex-end;margin-top:14px}.badge{display:inline-flex;align-items:center;gap:6px;white-space:nowrap;padding:5px 9px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase}.badge i{width:6px;height:6px;border-radius:50%;background:currentColor}.badge.brand{color:var(--color-brand);background:var(--color-brand-light)}.badge.warning{color:var(--color-warning);background:var(--color-warning-light)}.badge.danger{color:var(--color-danger);background:var(--color-danger-light)}.badge.neutral{color:var(--color-neutral-600);background:var(--color-neutral-200)}.badge.success{color:var(--color-success);background:var(--color-success-light)}.form{display:grid;gap:12px;margin-top:18px;padding-top:18px;border-top:1px solid var(--color-neutral-200)}.issue-form{padding:18px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-neutral-50)}.form h3{margin:0;font-size:16px}.form label{display:grid;gap:6px;color:var(--color-neutral-600);font-size:13px;font-weight:800}.form input,.form select,.form textarea{width:100%;border:1px solid var(--color-neutral-200);border-radius:8px;padding:10px 12px;color:var(--color-neutral-950);background:#fff}.form input[readonly]{color:var(--color-neutral-600);background:var(--color-neutral-100)}.form textarea{min-height:88px;resize:vertical}.compact-form{margin-top:0;padding-top:0;border-top:0}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.notification-preview{display:grid;gap:8px;margin-bottom:18px;padding:16px;border:1px solid var(--color-brand-light);border-radius:8px;background:var(--color-brand-light)}.notification-preview span{color:var(--color-brand);font-size:12px;font-weight:900;text-transform:uppercase}.notification-preview strong{font-size:17px}.notification-preview p{margin:0;color:var(--color-neutral-700);font-size:13px;line-height:1.45}.milestone-register{display:grid;gap:10px}.milestone-row{display:grid;grid-template-columns:minmax(150px,1fr) minmax(120px,.7fr) minmax(120px,.7fr) auto;align-items:center;gap:14px;padding:14px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-neutral-50)}.milestone-row span,.milestone-row strong{display:block}.milestone-row span{color:var(--color-neutral-600);font-size:12px;font-weight:800}.milestone-row strong{margin-top:3px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;display:grid;place-items:center;padding:20px;background:#1118277a}.modal{width:min(100%,620px);max-height:min(720px,calc(100vh - 40px));overflow:auto;padding:24px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white);box-shadow:0 24px 70px #11182747}.primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 14px;border-radius:8px;color:#fff;background:var(--color-brand);font-weight:800}.secondary-action{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-height:38px;padding:9px 12px;border:1px solid var(--color-brand);border-radius:8px;color:var(--color-brand);background:var(--color-white);font-weight:800;white-space:nowrap}.secondary-action:hover{background:var(--color-brand-light)}.primary:disabled{cursor:wait;opacity:.7}.success-button{background:var(--color-success)}.spin{animation:spin 1s linear infinite}.handover-alert{gap:8px;margin-bottom:14px;padding:12px 14px;border:1px solid rgba(183,121,31,.22);border-radius:8px;color:var(--color-warning);background:var(--color-warning-light);font-weight:800}.handover-alert.locked{border-color:var(--color-neutral-200);color:var(--color-neutral-700);background:var(--color-neutral-100)}.handover-summary{display:flex;align-items:baseline;gap:8px;margin-bottom:14px;color:var(--color-neutral-600);font-size:13px}.handover-summary strong{color:var(--color-neutral-950);font-size:18px}.checklist{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.checklist div{display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;align-items:center;padding:11px;border:1px solid var(--color-neutral-200);border-radius:8px;background:var(--color-white)}.checklist div.complete{border-color:#14795c2e;background:var(--color-success-light)}.checklist div.pending{border-color:#b7791f38;background:var(--color-warning-light)}.checklist span,.checklist small{min-width:0}.checklist span{color:var(--color-neutral-950);font-size:13px;font-weight:800;line-height:1.3}.checklist small{grid-column:2;color:var(--color-neutral-600);font-size:11px;font-weight:800}.ok{color:var(--color-success)}.warn{color:var(--color-warning)}.footer{display:flex;justify-content:center;gap:20px;padding:24px;color:#fff;background:var(--color-neutral-950);font-size:13px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes skeleton{0%{background-position:120% 0}to{background-position:-120% 0}}@media (max-width: 820px){.header{min-height:auto;gap:12px;padding:12px 14px}.brand{font-size:19px}.header-actions{gap:8px}.profile-trigger{min-width:138px;max-width:42vw}.notifications-popover{position:fixed;top:64px;right:12px;left:12px;width:auto;max-height:min(520px,calc(100vh - 84px))}.notifications-popover:before{display:none}.shell{padding:18px 14px 34px}.app-shell{grid-template-columns:1fr;gap:16px}.side-nav{position:static;padding:12px}.side-nav nav{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.side-nav button{flex:0 0 auto;min-width:168px}.admin-create-user{grid-template-columns:1fr}.hero{grid-template-columns:1fr;align-items:flex-start;min-height:auto;padding:24px 20px}.hero h1{font-size:30px}.hero-summary{width:100%;grid-template-columns:1fr}.hero-summary div{min-height:auto}.grid,.engineer-grid,.developer-grid{grid-template-columns:1fr}.integrations-grid .wide{grid-column:auto}.status-row{grid-template-columns:1fr}.wide{grid-column:auto}.timeline{grid-template-columns:1fr}.timeline-actions{align-items:flex-start;flex-direction:column}.buyer-select{width:100%;min-width:0}.buyer-profile-grid,.project-info-grid,.notice-item{grid-template-columns:1fr}.notice-item time{white-space:normal}.compliance-overview,.construction-summary,.payment-summary,.compliance-item{grid-template-columns:1fr}.construction-stage,.payment-row{grid-template-columns:1fr;align-items:start}.defect-card{grid-template-columns:1fr;padding:12px}.section-title.split,.defect-toolbar{align-items:flex-start;flex-direction:column}.defect-tabs,.defect-tabs button{width:100%}.defect-tabs{display:grid;grid-template-columns:1fr 1fr}.defect-tabs button{justify-content:center}.defect-card img,.defect-image-placeholder,.skeleton-media{width:100%;height:168px}.defect-card-body{padding:0}.checklist,.form-row,.milestone-row{grid-template-columns:1fr}.footer{flex-direction:column;align-items:center;gap:6px;text-align:center}.login-page{padding:16px}.login-panel{padding:24px}.login-copy h1{font-size:25px}}@media (max-width: 520px){.header{align-items:center}.profile-trigger{min-width:42px;width:42px;grid-template-columns:1fr;padding:0}.profile-trigger>span{display:none}.icon-button,.avatar{width:40px;height:40px}.card{padding:18px}.hero h1{font-size:27px}.section-title.split{gap:12px}.secondary-action,.primary{width:100%}}.impersonation-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 20px;background:#fef3c7;border:1px solid #fbbf24;border-radius:10px;margin-bottom:8px;font-size:13.5px;color:#92400e}.impersonation-banner strong{font-weight:600}.impersonation-banner button{flex-shrink:0;padding:5px 14px;border-radius:8px;border:1px solid #f59e0b;background:#fff;color:#92400e;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.impersonation-banner button:hover{background:#fef9ee}.admin-grid{display:flex;flex-direction:column;gap:20px}.admin-grid .wide{width:100%}.admin-header-card .section-title{margin-bottom:16px}.admin-create-user{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:18px;align-items:start;margin-bottom:18px;padding:18px;border:1px solid var(--border);border-radius:14px;background:linear-gradient(180deg,#3e60ff0f,#3e60ff05),var(--surface)}.admin-create-copy{display:grid;gap:10px}.admin-create-copy h3{margin:0;font-size:18px;line-height:1.25;color:var(--text-primary)}.admin-create-copy p{margin:0;color:var(--text-secondary);line-height:1.55}.admin-create-notes{margin:2px 0 0;padding-left:18px;display:grid;gap:6px;color:var(--text-secondary);font-size:13px}.admin-create-notes li{line-height:1.45}.admin-create-form{display:grid;gap:12px;margin-top:0}.admin-create-form label{gap:8px;color:var(--text-secondary);font-size:13px;font-weight:700}.admin-create-form input,.admin-create-form select{min-height:42px}.admin-field-helper{display:grid;gap:4px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-secondary);font-size:13px;line-height:1.45}.admin-field-helper.warning{border-color:#f59e0b66;background:#f59e0b14;color:#92400e}.invite-link-row{display:grid;gap:6px;color:var(--text-secondary);font-size:13px;font-weight:700}.admin-create-submit{margin-top:2px}.admin-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:16px}.stat-card{display:flex;flex-direction:column;align-items:flex-start;gap:4px;padding:14px 16px;border-radius:10px;border:1px solid var(--border);background:var(--surface)}.stat-card strong{font-size:22px;font-weight:700;line-height:1;color:var(--text-primary)}.stat-card span{font-size:12px;color:var(--text-muted)}.stat-card svg{color:var(--text-muted)}.stat-brand{border-left:3px solid var(--brand)}.stat-success{border-left:3px solid #10b981}.stat-warning{border-left:3px solid #f59e0b}.stat-neutral{border-left:3px solid var(--border)}.admin-filter-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.segment-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;border:1px solid var(--border);background:var(--surface);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s}.segment-btn span{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:18px;padding:0 5px;border-radius:999px;background:var(--border);font-size:11px;font-weight:600;color:var(--text-muted)}.segment-btn:hover,.segment-btn.active{border-color:var(--brand);background:var(--brand-light, #eef2ff);color:var(--brand)}.segment-btn.active span{background:var(--brand);color:#fff}.user-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}.user-card{display:flex;flex-direction:column;gap:12px;padding:16px}.user-card-header{display:flex;align-items:flex-start;gap:10px}.user-avatar{flex-shrink:0;width:34px;height:34px;border-radius:8px;background:var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.user-card-identity{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.user-card-identity strong{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.user-card-identity span{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card-meta{display:flex;gap:16px}.user-card-meta>div{display:flex;flex-direction:column;gap:2px}.user-card-meta span{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.user-card-meta strong{font-size:13px;font-weight:500;color:var(--text-primary)}.view-as-button{width:100%;justify-content:center;font-size:13px;padding:7px 12px;border-radius:8px;margin-top:2px}.dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.dialog-panel{background:var(--bg, #fff);border-radius:14px;padding:24px;width:100%;max-width:440px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;gap:16px}.dialog-header{display:flex;align-items:center;justify-content:space-between}.dialog-note{font-size:14px;color:var(--text-secondary);line-height:1.5;margin:0}.login-link-box{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:10px 14px;font-size:12px;color:var(--text-muted);font-family:monospace;word-break:break-all}.dialog-actions{display:flex;gap:10px}.dialog-actions .primary{flex:1}.dialog-hint{font-size:12px;color:var(--text-muted);margin:0;line-height:1.5}
