.portal{max-width:36rem;margin:0 auto;padding:0 1rem 6rem}.portal-bar{position:sticky;top:0;z-index:30;background:#f4f2eef0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid #E3DFD8;display:flex;align-items:center;gap:.6rem;padding:.75rem .25rem;margin:0 -.25rem .75rem}.portal-bar h1{font-size:1.15rem;font-weight:800;margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-bar .who{font-size:.8rem;color:#3a4250;white-space:nowrap}.portal-back{display:inline-flex;align-items:center;min-height:44px;min-width:44px;border:0;background:transparent;color:#171a1f;font:inherit;font-weight:700;cursor:pointer}.p-btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:56px;padding:0 1.4rem;border-radius:12px;font-weight:700;font-size:1rem;border:1px solid transparent;cursor:pointer;font-family:inherit}.p-btn-primary{background:#f59e0b;color:#171a1f}.p-btn-dark{background:#171a1f;color:#f4f2ee}.p-btn-ghost{background:#fff;border-color:#e3dfd8;color:#3a4250}.p-btn:disabled{opacity:.45;cursor:not-allowed}.p-btn-block{width:100%}.project-card{display:block;width:100%;text-align:left;background:#fff;border:1px solid #E3DFD8;border-radius:14px;padding:1rem 1.1rem;margin-bottom:.85rem;box-shadow:0 10px 30px -24px #171a1f66;cursor:pointer;font-family:inherit;color:inherit;min-height:56px}.project-card h3{font-size:1.1rem;font-weight:800;margin:0 0 .2rem}.project-card .meta{font-size:.85rem;color:#3a4250}.role-pill{display:inline-block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.12rem .5rem;border-radius:999px;background:#e3dfd8;color:#3a4250;margin-left:.4rem}.feed{margin-top:.5rem}.update-card{background:#fff;border:1px solid #E3DFD8;border-radius:14px;padding:.95rem 1rem;margin-bottom:.85rem;box-shadow:0 10px 30px -24px #171a1f66}.update-head{display:flex;align-items:center;gap:.5rem;margin-bottom:.45rem;flex-wrap:wrap}.type-badge{display:inline-block;font-size:.72rem;font-weight:800;padding:.18rem .55rem;border-radius:999px}.update-card h4{font-size:1.05rem;font-weight:800;margin:.1rem 0 .25rem}.update-card .body{color:#3a4250;font-size:.95rem;margin:0 0 .5rem;white-space:pre-wrap}.update-meta{font-size:.78rem;color:#3a4250}.update-card.is-pending{opacity:.72}.photo-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:.4rem;margin:.5rem 0}.photo-thumb{position:relative;border-radius:10px;overflow:hidden;background:#e3dfd8;aspect-ratio:1 / 1}.photo-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#171a1f73;z-index:40;border:0;cursor:pointer}.composer{position:fixed;left:0;right:0;bottom:0;z-index:41;background:#f4f2ee;border-radius:18px 18px 0 0;box-shadow:0 -18px 50px -20px #171a1f80;max-height:90vh;overflow-y:auto;padding:1rem 1.1rem calc(1.2rem + env(safe-area-inset-bottom));max-width:36rem;margin:0 auto}.composer-grab{width:38px;height:4px;border-radius:999px;background:#c9c3b7;margin:0 auto .85rem}.composer h2{font-size:1.2rem;font-weight:800;margin:0 0 .85rem}.type-grid{display:grid;grid-template-columns:1fr 1fr;gap:.55rem;margin-bottom:1rem}.type-btn{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;min-height:56px;padding:.7rem .85rem;border-radius:12px;border:2px solid #E3DFD8;background:#fff;font-family:inherit;font-weight:700;font-size:1rem;color:#171a1f;cursor:pointer}.type-btn[aria-pressed=true]{border-color:currentColor}.type-swatch{width:.85rem;height:.85rem;border-radius:4px}.p-field{display:block;margin-bottom:.9rem}.p-field>span{display:block;font-size:.85rem;font-weight:700;color:#3a4250;margin-bottom:.3rem}.p-input,.p-textarea{width:100%;box-sizing:border-box;border:1px solid #D8D2C6;border-radius:10px;padding:.7rem .8rem;font:inherit;font-size:16px;background:#fff;color:#171a1f}.p-textarea{min-height:5rem;resize:vertical}.p-input:focus,.p-textarea:focus{outline:3px solid #B45309;outline-offset:1px}.capture-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem}.capture-btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:56px;padding:0 1.1rem;border-radius:12px;border:2px dashed #C9C3B7;background:#fff;color:#3a4250;font:inherit;font-weight:700;cursor:pointer}.capture-btn input{display:none}.capture-tile{position:relative;width:72px;height:72px;border-radius:10px;overflow:hidden;background:#e3dfd8;flex:0 0 auto}.capture-tile img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.capture-tile .ring{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#171a1f80;color:#fff;font-size:.7rem;font-weight:700}.capture-tile .ring.err{background:#b91c1cc7}.capture-tile .rm{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:999px;border:0;background:#171a1fb3;color:#fff;font-size:.9rem;line-height:1;cursor:pointer}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:999px;animation:portal-spin .7s linear infinite}@keyframes portal-spin{to{transform:rotate(360deg)}}@media (prefers-reduced-motion: reduce){.spinner{animation:none}}.compose-fab-wrap{position:sticky;bottom:0;padding:.75rem 0 calc(.75rem + env(safe-area-inset-bottom));margin-top:.5rem;background:linear-gradient(to top,#f4f2ee 60%,#f4f2ee00)}.p-empty,.p-loading{text-align:center;color:#3a4250;padding:2.5rem 1rem}.p-error{background:#fdecec;color:#8a2424;border-radius:10px;padding:.75rem 1rem;margin:.75rem 0}.p-error .p-btn{margin-top:.5rem}.post-error{background:#fdecec;color:#8a2424;border-radius:10px;padding:.6rem .85rem;font-size:.9rem;margin-bottom:.75rem}.composer-actions{display:flex;gap:.6rem;margin-top:.5rem}.composer-actions .p-btn{flex:1}
