:root{color:#111827;background:#f3f6fb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{color:#111827;background:#f3f6fb;min-width:320px;margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{cursor:pointer}#root{min-height:100vh}.app-shell{grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.app-sidebar{color:#e2e8f0;background:#0f172a;flex-direction:column;gap:24px;height:100vh;padding:28px 20px;display:flex;position:sticky;top:0}.app-brand{align-items:center;gap:4px;display:flex}.app-brand__mark{color:#fff;background:#2563eb;border-radius:3px;place-items:center;width:76px;height:76px;font-weight:700;display:grid;box-shadow:0 12px 24px #2563eb3d}.app-brand__mark--image{box-shadow:none;background:0 0;padding:0;overflow:hidden}.app-brand__mark--image img{object-fit:contain;width:100%;height:100%;display:block}.app-brand__title{letter-spacing:.04em;font-size:1rem;font-weight:700;line-height:1.05}.app-brand__subtitle,.muted{color:#64748b;font-size:.92rem;line-height:1.15}.app-nav{flex-direction:column;gap:8px;display:flex}.app-nav__link{color:#cbd5e1;border-radius:8px;padding:12px 14px}.app-nav__link.active{color:#fff;background:#94a3b829}.app-sidebar__footer{gap:16px;margin-top:auto;display:grid}.user-summary__name{font-weight:600}.user-summary__meta{color:#94a3b8;font-size:.92rem}.app-content{min-width:0;padding:32px}.page{gap:20px;display:grid}.page-header{justify-content:space-between;align-items:start;gap:16px;display:flex}.page-header--projects{align-items:end}.page-header--project{align-items:start}.page-header__content{max-width:720px}.page-header h1,.auth-card h1{margin:4px 0 8px;font-size:clamp(2rem,3vw,2.6rem)}.page-header p,.auth-card p{color:#64748b;margin:0}.eyebrow{text-transform:uppercase;letter-spacing:.08em;color:#2563eb;font-size:.78rem;font-weight:700;display:inline-block}.toolbar,.chip-row,.form-actions{flex-wrap:wrap;gap:10px;display:flex}.toolbar--hero{justify-content:flex-end}.button{color:#111827;background:#e5e7eb;border:1px solid #0000;border-radius:8px;height:48px;max-height:60px;padding:11px 16px;transition:all .2s}.button:hover{filter:brightness(.98)}.button--primary{color:#fff;background:#2563eb}.button--ghost{background:#fff;border-color:#d7deea}.button--success{color:#047857;background:#ecfdf5;border-color:#a7f3d0}.button--warn{color:#c2410c;background:#fff7ed;border-color:#fdba74}.button--danger{color:#be123c;background:#fff1f2;border-color:#fecdd3}.button--soft{min-height:40px;padding:9px 13px;font-weight:600}.drawer-backdrop{z-index:60;-webkit-backdrop-filter:blur(6px);background:#0f172a57;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer-backdrop--centered{justify-content:center;align-items:center;padding:24px}.drawer{background:#fff;border-left:1px solid #e2e8f0;grid-template-rows:auto 1fr;width:min(100%,560px);height:100vh;animation:.24s drawer-in;display:grid;box-shadow:-24px 0 48px #0f172a1f}.drawer--project{padding:24px 24px 20px}.drawer__header{border-bottom:1px solid #eef2f7;justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:18px;display:flex}.drawer__title-group{gap:6px;display:grid}.drawer__title-group h2,.drawer__title-group p{margin:0}.drawer__title-group h2{font-size:1.5rem;line-height:1.15}.drawer__title-group p{color:#64748b}.drawer__close{color:#64748b;background:#fff;border:1px solid #d7deea;border-radius:999px;flex:none;justify-content:center;align-items:center;width:40px;height:40px;padding:0;display:inline-flex}.drawer__close svg{width:18px;height:18px}.drawer__body{align-content:start;gap:16px;padding-top:18px;overflow-y:auto}.drawer__footer{grid-column:1/-1;justify-content:flex-end;gap:10px;margin-top:4px;padding-top:8px;display:flex}.button--full{justify-content:center;width:100%}.alert-dialog{background:#fff;border:1px solid #e2e8f0;border-radius:18px;gap:18px;width:min(100%,420px);padding:22px;display:grid;box-shadow:0 24px 60px #0f172a33}.alert-dialog__body{gap:10px;display:grid}.alert-dialog__body h2,.alert-dialog__body p{margin:0}.alert-dialog__body h2{font-size:1.3rem;line-height:1.15}.alert-dialog__body p{color:#64748b;line-height:1.5}.alert-dialog__footer{justify-content:flex-end;gap:10px;display:flex}.panel,.project-card,.stat-card,.section-card,.expense-card,.auth-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 30px #0f172a0a}.panel,.auth-card{padding:20px}.panel-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.section-title{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-title--align-start{align-items:flex-start}.section-title--spaced{margin-top:24px}.section-title h2,.section-card h3,.expense-card h3,.project-card h2{margin:0;font-size:1.1rem}.filters,.form-grid,.two-column,.stats-grid,.project-grid,.section-list,.expense-list,.photo-grid{gap:16px;display:grid}.filters,.two-column{grid-template-columns:repeat(2,minmax(0,1fr))}.two-column--wide{align-items:start}.stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.project-grid--dense{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.project-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.form-grid--two{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid--three{grid-template-columns:repeat(3,minmax(0,1fr))}.field{gap:8px;display:grid}.field span{color:#475569;font-size:.92rem}.field input,.field select,.field textarea,.inline-form input{background:#fff;border:1px solid #d7deea;border-radius:8px;width:100%;padding:12px 14px}.field textarea{resize:vertical}.field--grow,.field--full{grid-column:1/-1}.checkbox-field{align-items:center;gap:10px;display:flex}.inline-form{gap:12px;margin-bottom:20px;display:flex}.chip,.status-pill{color:#475569;letter-spacing:0;background:#fff;border:1px solid #d7deea;border-radius:12px;justify-content:center;align-items:center;gap:8px;min-height:38px;padding:8px 13px;line-height:1.15;display:inline-flex;box-shadow:inset 0 1px #ffffff7a}.chip--active{background:#eff6ff}.chip__dot,.status-pill__dot{display:none}.chip--static{cursor:default}.chip--success{color:#047857;background:#ecfdf5;border-color:#a7f3d0}.notice{color:#1d4ed8;background:#eff6ff;border-radius:8px;padding:14px 16px}.notice--error{color:#be123c;background:#fff1f2}.projects-hero{gap:0;display:grid}.panel--projects-filters{z-index:12;-webkit-backdrop-filter:blur(18px);background:#ffffffe6;gap:12px;padding-top:10px;padding-bottom:10px;display:grid;position:sticky;top:16px;box-shadow:0 14px 28px #0f172a0f}.page-header--projects .page-header__content{gap:2px;display:grid}.page-header--projects h1{margin:0}.panel--projects-filters .panel-header{margin-bottom:8px}.panel--projects-filters .panel-header p{margin:0}.projects-counter{color:#64748b;font-weight:600}.projects-counter__value{color:#111827;font-variant-numeric:tabular-nums;font-size:1.12rem}.counter-skeleton{border-radius:999px;width:118px;height:22px}.panel--projects-filters .field{gap:6px}.chip-row--filters{gap:8px}.search-sort-row{align-items:end;gap:12px;display:flex}.search-sort-row .field--grow{flex:auto}.search-field{min-width:0}.search-field__control{align-items:center;display:flex;position:relative}.search-field__control input{padding-left:42px;padding-right:42px;transition:border-color .18s,box-shadow .18s,background-color .18s}.search-field__control input:focus{border-color:#93c5fd;outline:none;box-shadow:0 0 0 4px #2563eb17}.search-field__icon,.search-field__clear{color:#94a3b8;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex;position:absolute;top:50%;transform:translateY(-50%)}.search-field__icon{pointer-events:none;left:14px}.search-field__icon svg,.search-field__clear svg{width:18px;height:18px}.search-field__clear{color:#94a3b8;background:0 0;border:0;border-radius:999px;width:24px;height:24px;padding:0;transition:background-color .18s,color .18s;right:12px}.search-field__clear:hover{color:#2563eb;background:#eff6ff}.sort-text-button{color:#2563eb;white-space:nowrap;background:#fff;border:1px solid #d7deea;border-radius:8px;justify-content:center;align-items:center;min-width:176px;min-height:46px;padding:10px 14px;font-weight:600;display:inline-flex}.project-card{grid-template-rows:auto auto 1fr;align-content:start;gap:16px;min-height:300px;padding:22px;transition:transform .2s,box-shadow .2s,border-color .2s;display:grid;overflow:hidden}.project-card:hover{border-color:#a9c2ea;transform:translateY(-4px)scale(1.01);box-shadow:0 22px 44px #0f172a1f,0 8px 18px #2563eb14}@keyframes project-card-in{0%{opacity:0;transform:translateY(8px)scale(.99)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes drawer-in{0%{opacity:0;transform:translate(32px)}to{opacity:1;transform:translate(0)}}.project-grid--animated .project-card{animation:.22s both project-card-in}.project-grid--animated .project-card:nth-child(2n){animation-delay:30ms}.project-grid--animated .project-card:nth-child(3n){animation-delay:50ms}.project-grid--loading .project-card{animation:.22s both project-card-in}.project-card__head,.project-card__stats,.section-card__header,.expense-card__head,.timeline-item__head,.list-item,.table__head,.table__row{justify-content:space-between;align-items:start;gap:12px;display:flex}.project-card__head{grid-template-columns:minmax(0,1fr) max-content;align-items:start;gap:14px;display:grid}.project-card__code{color:#2563eb;font-size:.9rem;font-weight:600}.project-card__title-group{gap:8px;min-width:0;display:grid}.project-card__title-group h2{overflow-wrap:anywhere;-webkit-line-clamp:5;-webkit-box-orient:vertical;margin:0;font-size:1.2rem;line-height:1.25;display:-webkit-box;overflow:hidden}.project-card__eyebrow{flex-wrap:wrap;align-items:center;gap:10px;min-width:0;display:flex}.project-card__number{color:#94a3b8;font-size:.9rem}.project-card__meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;min-height:62px;display:grid}.project-meta-item{color:#64748b;gap:4px;min-width:0;display:grid}.project-meta-item strong{color:#94a3b8;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem}.project-card__stats div,.stat-card{gap:6px;display:grid}.stat-card{padding:18px}.stat-card span{color:#64748b}.project-card__stats{grid-template-columns:1fr;align-items:end;gap:12px;margin-top:auto;display:grid}.project-card__stats div{background:0 0;border:0;border-radius:0;padding:0}.project-card__budget{text-align:right;color:#16a34a;place-self:end;font-size:1.22rem;font-weight:700;line-height:1}.status-pill{white-space:normal;overflow-wrap:anywhere;box-sizing:border-box;text-align:center;justify-content:center;justify-self:end;align-items:center;width:auto;max-width:none;min-height:42px;padding:8px 9px;font-size:.84rem;font-weight:700;line-height:1.1;transition:box-shadow .2s,border-color .2s,transform .2s,background-color .2s,color .2s}.project-card:hover .status-pill{box-shadow:inset 0 1px #ffffff94,0 10px 24px #0f172a1a}.project-card--skeleton{pointer-events:none}.status-pill--skeleton{border:0;width:132px;max-width:132px;min-height:42px}.skeleton-line{border-radius:999px;display:block}.skeleton-line--lg{width:88%;height:18px}.skeleton-line--md{width:72%;height:16px}.skeleton-line--sm{width:96px;height:14px}.skeleton-line--xs{width:64px;height:11px}.shimmer-block{background:linear-gradient(#edf2f8,#e6edf6);position:relative;overflow:hidden}.shimmer-block:after{content:"";background:linear-gradient(90deg,#fff0 0%,#ffffff8a 48%,#fff0 100%);animation:1.35s ease-in-out infinite shimmer-slide;position:absolute;inset:0;transform:translate(-100%)}@keyframes shimmer-slide{to{transform:translate(100%)}}.status-pill--hero{align-self:flex-end;min-height:38px;padding:7px 10px;font-size:.9rem}.project-hero-card{background:linear-gradient(#fffffff5,#f6fafff5);padding:24px}.project-hero-card__content{gap:10px;display:grid}.project-hero-card__content h1{margin:0;line-height:1.15}.project-hero-card__meta{flex-wrap:wrap;gap:10px;display:flex}.project-hero-card__meta span{color:#556274;background:#f8fafc;border:1px solid #e5edf7;border-radius:999px;align-items:center;min-height:34px;padding:6px 12px;font-size:.9rem;display:inline-flex}.project-hero-card__aside{justify-items:end;gap:14px;display:grid}.project-status-action{color:#fff;border:0;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;min-width:min(100%,300px);min-height:52px;padding:12px 16px 12px 18px;font-weight:700;transition:transform .2s,box-shadow .2s,filter .2s;display:inline-flex;box-shadow:0 18px 36px #0f172a29}.project-status-action:hover:not(:disabled){filter:saturate(1.04);transform:translateY(-1px);box-shadow:0 22px 40px #0f172a33}.project-status-action:disabled{opacity:.65;cursor:wait}.project-status-action__arrow{background:#ffffff2e;border-radius:999px;flex:none;justify-content:center;align-items:center;width:26px;height:26px;font-size:1rem;display:inline-flex}.panel--elevated{background:linear-gradient(#fffffffa,#f9fbfefa);padding:22px}.project-status-panel{gap:18px}.project-overview-grid{grid-template-columns:minmax(320px,1.15fr) minmax(280px,.9fr) minmax(280px,.95fr);align-items:start;gap:16px;display:grid}.project-import-card{background:linear-gradient(#f8fbfff5,#fffffffa);border:1px solid #dde6f1;border-radius:18px;gap:16px;margin-bottom:20px;padding:18px;display:grid}.project-import-card__head{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.project-import-card__head strong{margin-bottom:4px;font-size:1rem;display:block}.project-import-card__controls{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:14px;display:grid}.project-import-card__upload{align-self:end;min-height:46px}.project-import-draft{background:#fff;border:1px solid #dbe7f3;border-radius:16px;gap:14px;padding:16px;display:grid}.project-import-draft__meta{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.project-import-draft__meta strong,.project-import-item strong{margin:0}.project-import-draft__meta small,.project-import-item small{color:#64748b}.project-import-draft__meta>div{gap:4px;display:grid}.project-import-items{gap:10px;display:grid}.project-import-item{background:#f8fafc;border:1px solid #e5edf6;border-radius:14px;gap:4px;padding:14px 16px;display:grid}.project-import-item span{color:#334155;font-size:.94rem}.project-import-empty{color:#64748b;background:#f8fafc;border-radius:14px;padding:14px 16px}.big-section-list{gap:14px;display:grid}.big-section-card{background:linear-gradient(#fffffffc,#f9fbfefc);border:1px solid #dbe5f1;border-radius:18px;overflow:hidden}.big-section-card__header{text-align:left;width:100%;color:inherit;background:0 0;border:0;justify-content:space-between;align-items:center;gap:14px;padding:18px;display:flex}.big-section-card__meta{gap:4px;display:grid}.big-section-card__number{color:#64748b;text-transform:uppercase;font-size:.8rem;font-weight:700}.big-section-card__meta h3,.sub-section-card__head h4{margin:0}.big-section-card__meta h3{font-size:1.15rem}.big-section-card__chevron{color:#94a3b8;flex:none;font-size:1.4rem;transition:transform .2s}.big-section-card__chevron.is-open{transform:rotate(180deg)}.big-section-card__body{gap:14px;padding:0 14px 14px;display:grid}.big-section-card__actions{justify-content:space-between;align-items:center;gap:12px;padding-top:4px;display:flex}.big-section-card__subsections{gap:12px;display:grid}.sub-section-card{background:#f6f8fb;border:1px solid #e2e8f0;border-radius:16px;overflow:hidden}.sub-section-card__main{width:100%;color:inherit;text-align:left;background:0 0;border:0;gap:14px;padding:16px;display:grid}.sub-section-card__head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.sub-section-card__head .muted{margin-bottom:4px;display:inline-block}.sub-section-card__arrow{color:#94a3b8;flex:none;font-size:1.3rem}.sub-section-card__stats{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.sub-section-card__stat{gap:4px;display:grid}.sub-section-card__stat span{color:#64748b;font-size:.82rem}.sub-section-card__stat strong{font-size:.98rem}.sub-section-card__stat--money strong{color:#16a34a}.sub-section-card__actions{gap:12px;padding:0 16px 16px;display:grid}.project-history-actions{margin-top:14px}.project-access-shell{gap:18px;display:grid}.project-access-shell__hero{justify-content:space-between;align-items:flex-start;gap:14px;display:flex}.project-access-shell__hero h2,.project-access-shell__hero p{margin:0}.project-access-shell__hero p{color:#64748b;margin-top:6px}.project-access-tabs{width:fit-content}.project-access-list,.project-access-summary__list{gap:12px;display:grid}.project-access-card{background:linear-gradient(#fffffffc,#f8fafcfc);border:1px solid #e2e8f0;border-radius:18px;justify-content:space-between;align-items:center;gap:14px;width:100%;padding:16px 18px;display:flex;box-shadow:0 10px 24px #0f172a0a}.project-access-card--interactive{text-align:left;color:inherit;transition:transform .18s,box-shadow .18s,border-color .18s}.project-access-card--interactive:hover{border-color:#c6d6eb;transform:translateY(-1px);box-shadow:0 16px 32px #0f172a14}.project-access-card__user,.project-access-selection{align-items:center;gap:14px;min-width:0;display:flex}.project-access-card__meta,.project-access-selection__meta,.project-access-picker__meta{gap:4px;min-width:0;display:grid}.project-access-card__meta strong,.project-access-selection__meta strong,.project-access-picker__meta strong{font-size:.98rem}.project-access-card__meta span,.project-access-selection__meta span,.project-access-picker__meta span{color:#475569;font-size:.92rem}.project-access-card__meta small,.project-access-selection__meta small,.project-access-picker__meta small,.project-access-card__side small{color:#94a3b8}.project-access-card__badges{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.project-access-card__side{justify-items:end;gap:6px;display:grid}.project-access-badge{color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;justify-content:center;align-items:center;min-height:32px;padding:6px 10px;font-size:.84rem;font-weight:700;display:inline-flex}.project-access-badge--blue{color:#1d4ed8;background:#eff6ff;border-color:#bfdbfe}.project-access-badge--green{color:#047857;background:#ecfdf5;border-color:#a7f3d0}.project-access-empty,.project-access-empty-inline{color:#64748b}.project-access-empty{background:#f8fafc;border:1px dashed #d7e2ef;border-radius:16px;justify-items:start;gap:8px;padding:18px;display:grid}.project-access-empty.compact{padding:16px}.project-access-empty p{margin:0}.project-access-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.project-access-summary__panel{background:#fbfdff;border:1px solid #e2e8f0;border-radius:18px;gap:12px;padding:16px;display:grid}.project-access-summary__panel-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.project-access-summary__panel-head strong{font-size:.98rem}.project-access-summary__panel-head span{color:#1d4ed8;background:#eff6ff;border-radius:999px;justify-content:center;align-items:center;min-width:34px;min-height:34px;padding:0 10px;font-weight:700;display:inline-flex}.project-access-summary__footer{justify-content:flex-end;display:flex}.project-access-drawer{max-width:580px}.project-access-drawer__body{gap:18px;display:grid}.project-access-picker,.project-access-permissions{gap:12px;display:grid}.project-access-picker{max-height:360px;overflow:auto}.project-access-picker__card,.project-access-permission{text-align:left;width:100%;color:inherit;background:#fff;border:1px solid #dbe5f1;border-radius:16px;justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;transition:border-color .18s,background-color .18s,box-shadow .18s;display:flex}.project-access-picker__card:hover,.project-access-permission:hover{border-color:#bfd0e5;box-shadow:0 10px 24px #0f172a0d}.project-access-picker__card.is-selected{background:#eff6ff;border-color:#93c5fd}.project-access-picker__mark{color:#2563eb;font-size:.88rem;font-weight:700}.project-access-permission{align-items:flex-start}.project-access-permission>div{gap:6px;display:grid}.project-access-permission strong{font-size:.97rem}.project-access-permission span{color:#64748b}.project-access-permission.is-active.is-view{background:#eff6ff;border-color:#bfdbfe}.project-access-permission.is-active.is-edit{background:#ecfdf5;border-color:#a7f3d0}.project-access-permission__toggle{color:#0f172a;background:#e2e8f0;border-radius:999px;flex:none;justify-content:center;align-items:center;min-width:54px;min-height:34px;padding:0 12px;font-size:.84rem;font-weight:700;display:inline-flex}.project-access-permission.is-active.is-view .project-access-permission__toggle{color:#fff;background:#2563eb}.project-access-permission.is-active.is-edit .project-access-permission__toggle{color:#fff;background:#10b981}.project-access-drawer__footer{justify-content:space-between;align-items:center;gap:14px;display:flex}.user-avatar--access{width:52px;height:52px}.panel--materials{gap:18px;display:grid}.materials-toolbar{justify-content:space-between;align-items:center;gap:14px;display:flex}.materials-toolbar__meta{color:#64748b;font-weight:600}.materials-segmented{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px;grid-template-columns:repeat(2,minmax(0,1fr));padding:4px;display:inline-grid}.materials-segmented__button{color:#64748b;background:0 0;border:0;border-radius:10px;min-width:148px;min-height:42px;padding:10px 14px;font-weight:600}.materials-segmented__button.is-active{color:#111827;background:#fff;box-shadow:0 8px 18px #0f172a14}.materials-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;display:grid}.material-card{background:linear-gradient(#fffffffa,#f8fafdfa);border:1px solid #e2e8f0;border-radius:8px;gap:18px;padding:20px;display:grid;box-shadow:0 10px 30px #0f172a0a}.material-card__body{gap:10px;display:grid}.material-card__title-row{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.material-card__title-row h2,.material-card__body p{margin:0}.material-card__title-row h2{font-size:1.08rem;line-height:1.25}.material-card__metric{flex:none;align-content:start;justify-items:end;gap:4px;display:grid}.material-card__measure{color:#0f766e;white-space:nowrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;align-items:center;min-height:32px;padding:6px 10px;font-size:.88rem;font-weight:700;display:inline-flex}.material-card__metric-label{color:#64748b;font-size:.76rem;font-weight:600;line-height:1}.material-card__actions,.material-set-list{flex-wrap:wrap;gap:8px;display:flex}.material-set-chip{color:#1d4ed8;background:#eff6ff;border-radius:999px;align-items:center;min-height:30px;padding:6px 10px;font-size:.86rem;font-weight:600;display:inline-flex}.materials-empty-state{border-style:dashed}.materials-picker{gap:12px;display:grid}.materials-picker__list{gap:10px;max-height:320px;padding-right:4px;display:grid;overflow-y:auto}.materials-picker__item{text-align:left;background:#fff;border:1px solid #dbe4f0;border-radius:14px;justify-content:space-between;align-items:center;gap:12px;width:100%;padding:14px 16px;display:flex}.materials-picker__item div{gap:3px;display:grid}.materials-picker__item span{color:#64748b;font-size:.92rem}.materials-picker__item.is-active{background:#dbeafe73;border-color:#93c5fd}.materials-picker__check{white-space:nowrap;font-weight:700;color:#2563eb!important}.section-card{background:linear-gradient(#fffffffa,#f8fafdfa);border:1px solid #e5edf7;gap:12px;padding:16px}.section-card__title-group{gap:4px;display:grid}.section-card__summary{color:#556274;margin:0;font-size:.92rem}.list-item,.timeline-item{gap:14px}.section-list{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.section-card .list{gap:8px}.section-card .list-item{padding:10px 0}.list-item strong,.timeline-item strong{line-height:1.25;display:block}.timeline-item{padding:14px 0}.timeline-item p{color:#556274;margin:0}.list,.timeline{gap:12px;display:grid}.list-item,.timeline-item,.table__row{border-bottom:1px solid #eef2f7;padding:12px 0}.table__head{color:#64748b;border-bottom:1px solid #d7deea;padding-bottom:10px;font-size:.92rem}.table__head,.table__row{grid-template-columns:2fr 1fr 1fr 1.4fr;display:grid}.users-table__row{align-items:center}.user-cell{align-items:center;gap:14px;min-width:0;display:flex}.user-avatar{color:#1d4ed8;background:#dbeafe;border-radius:50%;flex:none;place-items:center;width:48px;height:48px;font-weight:700;display:grid;overflow:hidden}.user-avatar img{object-fit:cover;width:100%;height:100%}.user-cell__content{gap:3px;min-width:0;display:grid}.role-cell{gap:4px;display:grid}.field--compact{gap:4px}.field--compact span{color:#94a3b8;font-size:.78rem}.field--compact select{min-width:220px;padding-block:10px}.status-badge{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;min-height:34px;padding:7px 12px;font-size:.88rem;font-weight:700;display:inline-flex}.status-badge--active{color:#047857;background:#ecfdf5;border-color:#a7f3d0}.status-badge--pending{color:#c2410c;background:#fff7ed;border-color:#fdba74}.status-badge--blocked{color:#be123c;background:#fff1f2;border-color:#fecdd3}.status-badge--neutral{color:#475569;background:#f8fafc;border-color:#dbe4f0}.users-actions{flex-wrap:wrap;justify-content:flex-start;gap:8px;display:flex}.analytics-stats-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.page-header--analytics .page-header__content{max-width:820px}.analytics-dashboard-grid{grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:16px;display:grid}.analytics-dashboard-grid--secondary{grid-template-columns:repeat(2,minmax(0,1fr))}.analytics-card{position:relative;overflow:hidden}.analytics-card--accent{background:linear-gradient(#2563eb14,#fffffffa)}.analytics-card p{color:#64748b;margin:0}.analytics-card--chart,.analytics-card--flow{gap:20px}.analytics-donut-layout{grid-template-columns:240px minmax(0,1fr);align-items:center;gap:20px;display:grid}.analytics-donut{aspect-ratio:1;width:100%;max-width:220px;margin:0 auto;position:relative}.analytics-donut svg{width:100%;height:100%}.analytics-donut__track{fill:none;stroke:#e5edf7;stroke-width:18px}.analytics-donut__center{text-align:center;place-content:center;display:grid;position:absolute;inset:0}.analytics-donut__center strong{font-size:2rem;line-height:1}.analytics-donut__center span,.analytics-muted{color:#64748b;font-size:.92rem}.analytics-status-list{gap:12px;display:grid}.analytics-status-row{border-bottom:1px solid #eef2f7;grid-template-columns:minmax(0,1fr) auto;gap:12px;padding:12px 0;display:grid}.analytics-status-row__label{gap:6px;min-width:0;display:grid}.analytics-status-row__label small{color:#94a3b8}.analytics-status-row__meta{text-align:right;gap:4px;display:grid}.analytics-status-row__meta span{color:#64748b;font-size:.9rem}.status-pill--analytics{justify-self:start;max-width:max-content;min-height:38px}.analytics-bars{grid-template-columns:repeat(6,minmax(0,1fr));align-items:end;gap:12px;min-height:240px;display:grid}.analytics-bars__item{justify-items:center;gap:10px;display:grid}.analytics-bars__canvas{background:linear-gradient(#f8fbff,#f1f5f9);border:1px solid #e5edf7;border-radius:16px;grid-template-columns:repeat(2,minmax(0,1fr));align-items:end;gap:8px;width:100%;min-height:180px;padding:14px 10px 10px;display:grid}.analytics-bars__bar{border-radius:999px 999px 10px 10px;width:100%;min-height:4px;transition:height .3s}.analytics-bars__bar--projects{background:linear-gradient(#2563eb,#60a5fa)}.analytics-bars__bar--budget{background:linear-gradient(#16a34a,#4ade80)}.analytics-bars__item strong{text-transform:capitalize}.analytics-bars__item span{color:#64748b;font-size:.9rem}.analytics-bars__legend{color:#64748b;flex-wrap:wrap;gap:16px;font-size:.92rem;display:flex}.analytics-bars__legend span{align-items:center;gap:8px;display:inline-flex}.analytics-legend-dot{border-radius:999px;width:10px;height:10px;display:inline-block}.analytics-legend-dot--projects{background:#2563eb}.analytics-legend-dot--budget{background:#16a34a}.analytics-project-list{gap:12px;display:grid}.analytics-project-row{border-bottom:1px solid #eef2f7;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;padding:14px 0;display:grid}.analytics-project-row__main,.analytics-project-row__side{gap:6px;display:grid}.analytics-project-row__main{min-width:0}.analytics-project-row__main strong{line-height:1.3}.analytics-project-row__main span,.analytics-project-row__side span{color:#64748b;font-size:.92rem}.analytics-project-row__side{justify-items:end}.analytics-skeleton-circle{border-radius:50%;width:220px;height:220px;margin-inline:auto}.analytics-skeleton-bars{grid-template-columns:repeat(5,minmax(0,1fr));align-items:end;gap:10px;min-height:220px;display:grid}.analytics-skeleton-bar{border-radius:16px 16px 8px 8px;width:100%}.analytics-skeleton-bar:first-child{height:42%}.analytics-skeleton-bar:nth-child(2){height:78%}.analytics-skeleton-bar:nth-child(3){height:55%}.analytics-skeleton-bar:nth-child(4){height:88%}.analytics-skeleton-bar:nth-child(5){height:64%}.section-card,.expense-card{gap:16px;padding:18px;display:grid}.expense-card__body{gap:6px;display:grid}.photo-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.photo-card{gap:8px;display:grid}.photo-card__preview{background:#f8fafc;border:1px solid #d7deea;border-radius:8px;min-height:140px;overflow:hidden}.photo-card__preview img,.profile-avatar img{object-fit:cover;width:100%;height:100%}.auth-page{background:#fff;place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{width:min(100%,480px)}.auth-card--mobile{width:min(100%,420px);box-shadow:none;background:0 0;border:0;padding:12px 24px 24px}.auth-card__header{text-align:center;justify-items:center;margin-bottom:24px;display:grid}.auth-logo-wrap{place-items:center;width:220px;height:220px;margin-bottom:6px;display:grid}.auth-logo{object-fit:contain;width:100%;height:100%}.auth-card--mobile h1{margin:0;font-size:2.15rem;line-height:1.1}.auth-card--mobile .form-grid{gap:14px}.auth-card--mobile .field input{background:#f7f9fc;border-color:#edf1f6;border-radius:18px;min-height:56px;padding-inline:16px}.auth-card--mobile .field span{display:none}.auth-card--mobile .button{border-radius:18px;min-height:56px;font-weight:600}.auth-card--mobile .notice{text-align:center}.auth-card--register{width:min(100%,460px)}.auth-card__header--compact{margin-bottom:18px}.auth-subtitle{color:#8a94a6;margin:6px 0 0;font-size:.95rem}.company-picker{gap:10px;display:grid}.company-card{text-align:left;background:#f7f9fc;border:1px solid #edf1f6;border-radius:18px;gap:4px;padding:14px 16px;display:grid}.company-card--active{background:#0d6efd1f;border-color:#0d6efd}.company-card__title{color:#111827;font-weight:700}.company-card__meta{color:#8a94a6;font-size:.88rem}.auth-link{text-align:center;color:#8a94a6;font-size:.95rem}.auth-link span{color:#0d6efd;font-weight:700}.empty-state{justify-items:start}.empty-state h2,.empty-state p{margin:0}.profile-avatar{color:#1d4ed8;background:#dbeafe;border-radius:50%;place-items:center;width:88px;height:88px;font-size:1.75rem;font-weight:700;display:grid;overflow:hidden}.page-header--profile h1{margin-bottom:6px}.profile-hero{padding:0;overflow:hidden}.profile-hero__cover{background:radial-gradient(circle at 20% 20%,#ffffff47,#0000 26%),linear-gradient(135deg,#0f4fe0 0%,#1d4ed8 40%,#0f172a 100%);min-height:160px}.profile-hero__body{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:20px;margin-top:-10px;padding:25px 26px 24px;display:grid}.profile-hero__identity{align-items:flex-start;gap:20px;min-width:0;display:flex}.profile-avatar--hero{background:#eef4ff;border:6px solid #fff;border-radius:28px;flex:none;width:156px;height:156px;margin-top:-60px;box-shadow:0 16px 34px #0f172a1f}.profile-hero__meta{gap:6px;min-width:0;padding-bottom:3px;display:grid}.profile-hero__meta h2,.profile-hero__meta p{margin:0}.profile-hero__meta h2{font-size:clamp(2rem,3vw,2.5rem);line-height:1.05}.profile-hero__role{color:#475569;font-size:1.02rem;font-weight:700}.profile-hero__subline{color:#64748b}.profile-hero__actions{align-self:end;gap:10px;margin-top:12px;display:flex}.profile-dashboard{align-items:start;gap:16px;display:grid}.profile-dashboard--managed{grid-template-columns:minmax(300px,420px) minmax(360px,620px);justify-content:start}.profile-dashboard__admin{gap:16px;width:100%;max-width:420px;display:grid}.profile-action-card,.profile-tasks-card,.profile-form-card{gap:16px;display:grid}.profile-tasks-card{align-content:start;width:100%;max-width:620px}.profile-action-card{grid-template-columns:auto minmax(0,1fr) auto;align-items:center;padding:22px}.profile-action-card__icon{color:#2563eb;background:#eff6ff;border-radius:14px;place-items:center;width:46px;height:46px;font-weight:800;display:grid}.profile-action-card__content{gap:6px;min-width:0;display:grid}.profile-action-card__content h3,.profile-action-card__content p{margin:0}.profile-action-card__content p{color:#64748b}.profile-task-list{gap:10px;display:grid}.profile-task-item{background:linear-gradient(#fffffffa,#f8fafdfa);border:1px solid #e5edf7;border-radius:16px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px 16px;display:grid}.profile-task-item__main,.profile-task-item__side{gap:6px;display:grid}.profile-task-item__main{min-width:0}.profile-task-item__main span,.profile-task-item__side small,.profile-task-empty{color:#64748b}.profile-task-badge{color:#c2410c;background:#fff7ed;border-radius:999px;justify-content:center;align-items:center;min-height:32px;padding:6px 10px;font-size:.86rem;font-weight:700;display:inline-flex}.profile-task-item__side{justify-items:end}.profile-task-empty{background:#f8fafc;border-radius:14px;margin:0;padding:18px}.profile-form-card{padding:22px}@media (width<=1100px){.app-shell{grid-template-columns:1fr}.app-sidebar{height:auto;position:static}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.analytics-dashboard-grid,.analytics-dashboard-grid--secondary,.analytics-donut-layout,.project-overview-grid,.project-import-card__controls,.project-access-summary{grid-template-columns:1fr}.project-access-shell__hero,.project-access-drawer__footer,.big-section-card__actions{flex-direction:column;align-items:flex-start}.profile-dashboard--managed,.profile-hero__body,.profile-action-card{grid-template-columns:1fr}.profile-hero__actions{align-self:start}}@media (width<=820px){.app-content{padding:20px}.panel--projects-filters{top:10px}.page-header,.two-column,.form-grid--two,.form-grid--three,.table__head,.table__row{grid-template-columns:1fr}.page-header,.section-card__header,.expense-card__head,.list-item,.project-access-card,.project-access-card__user,.project-access-drawer__footer{flex-direction:column}.sub-section-card__stats,.project-card__head,.project-card__stats{grid-template-columns:1fr}.project-card{min-height:auto}.project-hero-card__aside{justify-items:start}.status-pill,.status-pill--hero{align-self:start;max-width:100%}.project-card__budget{text-align:left;justify-self:start}.inline-form{flex-direction:column}.stats-grid,.analytics-stats-grid{grid-template-columns:1fr}.analytics-bars{grid-template-columns:repeat(3,minmax(0,1fr))}.analytics-project-row{grid-template-columns:1fr}.analytics-project-row__side{justify-items:start}.profile-hero__body{margin-top:-32px;padding:0 18px 18px}.profile-hero__identity,.profile-hero__actions{flex-direction:column;align-items:flex-start}.profile-avatar--hero{border-radius:22px;width:124px;height:124px}.profile-task-item,.profile-action-card{grid-template-columns:1fr}.profile-task-item__side{justify-items:start}.panel-header{flex-direction:column;align-items:start}.project-card__meta{grid-template-columns:1fr}.project-hero-card__meta{flex-direction:column}.search-sort-row{flex-direction:column;align-items:stretch}.materials-toolbar,.material-card__title-row,.materials-picker__item{flex-direction:column;align-items:flex-start}.materials-segmented{width:100%}.materials-segmented__button{min-width:0}.drawer{width:100%}.drawer--project{padding:18px 16px 16px}.drawer__footer{flex-direction:column-reverse}.user-cell{align-items:flex-start}.project-access-card__badges,.project-access-card__side{justify-items:start}}
