@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg-color: #f5f7fa;--surface-color: #ffffff;--primary-color: #2b6cb0;--text-main: #2d3748;--text-muted: #718096;--border-color: #e2e8f0;--safe-area-bottom: env(safe-area-inset-bottom, 20px)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,sans-serif;background-color:var(--bg-color);color:var(--text-main);height:100vh;width:100vw;overflow:hidden;display:flex;flex-direction:column}#app{display:flex;flex-direction:column;height:100%;position:relative}header{height:60px;background-color:var(--surface-color);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.1rem;box-shadow:0 1px 3px #0000000d;flex-shrink:0}main{flex:1;overflow-y:auto;padding:20px}.view{display:none;animation:fadeIn .2s ease-in-out}.view.active{display:block}.view.active>*{animation:riseIn .26s ease-out}.status-banner{border-radius:12px;padding:12px 14px;margin-bottom:16px;border:1px solid var(--border-color);background:#edf2f7;color:var(--text-main)}.status-banner.hidden{display:none}.status-banner.error{background:#fff5f5;border-color:#feb2b2;color:#c53030}.status-banner.success{background:#f0fff4;border-color:#9ae6b4;color:#2f855a}nav{height:calc(60px + var(--safe-area-bottom));background-color:var(--surface-color);border-top:1px solid var(--border-color);display:flex;padding-bottom:var(--safe-area-bottom);flex-shrink:0}nav button{flex:1;background:none;border:none;color:var(--text-muted);font-size:.85rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:color .2s;position:relative}nav button:hover,nav button.active{color:var(--primary-color)}nav button i{font-style:normal;font-size:1.2rem}.nav-badge{position:absolute;top:8px;right:calc(50% - 28px);min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#e53e3e;color:#fff;font-size:.72rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}.card{background:linear-gradient(180deg,#fffffff2,#f8fafce6);border-radius:12px;padding:16px;margin-bottom:16px;box-shadow:0 10px 30px #0f172a0d;border:1px solid var(--border-color);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.card-title{font-weight:600;margin-bottom:8px}.title-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.inline-alert-dot{width:10px;height:10px;border-radius:999px;background:#e53e3e;flex-shrink:0}.card-content{color:var(--text-muted);font-size:.95rem;line-height:1.45}.dashboard-grid{display:grid;gap:12px;margin-bottom:16px}.dashboard-card{width:100%;text-align:left;background:linear-gradient(180deg,#fffffff5,#f7fafce6);border:1px solid var(--border-color);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px;cursor:pointer;box-shadow:0 12px 28px #0f172a0d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.dashboard-card-state{color:var(--primary-color);font-size:.76rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.dashboard-card-title{color:var(--text-main);font-size:1rem;font-weight:600}.dashboard-card-body{color:var(--text-muted);font-size:.92rem;line-height:1.45}.stack{display:flex;flex-direction:column;gap:12px}.input,.textarea,.button{width:100%;border-radius:10px;border:1px solid var(--border-color);padding:12px 14px;font:inherit}.field-label{font-size:.9rem;font-weight:600;color:var(--text-main)}.field-help{color:var(--text-muted);font-size:.88rem;line-height:1.4}.upload-meta{display:flex;align-items:center;gap:8px}.upload-meta:before{content:"◌";color:#2b6cb0;font-size:.9rem}.upload-progress{display:grid;gap:8px}.upload-progress-bar{position:relative;overflow:hidden;height:8px;border-radius:999px;background:#ffffff24;border:1px solid rgba(255,255,255,.08)}.upload-progress-fill{display:block;width:40%;height:100%;border-radius:inherit;background:linear-gradient(90deg,#ffc4574d,#ffc457f2);animation:uploadPulse 1.2s ease-in-out infinite}@keyframes uploadPulse{0%{transform:translate(-100%)}to{transform:translate(250%)}}.textarea{resize:vertical;min-height:96px}.button{background:var(--surface-color);color:var(--text-main);cursor:pointer;transition:opacity .2s ease,transform .2s ease}.button.primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.button.warning{background:linear-gradient(180deg,#fff5f5,#fed7d7);color:#c53030;border-color:#feb2b2}.button.ghost{width:auto;padding:8px 12px;background:transparent;color:var(--primary-color);border-color:#2b6cb02e}.button.bookmark-button{width:auto;min-width:48px;padding:10px 12px;font-size:1.1rem;line-height:1;transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease}.button.bookmark-button.saved{background:linear-gradient(180deg,#fff8d6,#f6e05e);color:#975a16;border-color:#d69e2e;box-shadow:0 0 #f6e05e00}.button.bookmark-button:hover:not(:disabled),.button.bookmark-button.saved:hover:not(:disabled){box-shadow:0 0 18px #f6e05e73}.button:disabled,.input:disabled,.textarea:disabled{opacity:.65;cursor:not-allowed}.button:not(:disabled):active{transform:translateY(1px)}.request-item{border-top:1px solid var(--border-color);padding-top:12px;margin-top:12px}.premium-request-card{background:linear-gradient(180deg,#fffffffa,#f1f5f9eb);border-radius:14px;padding:14px}.requests-hero-card{background:linear-gradient(180deg,#fffffffa,#ebf8ffeb)}.requests-bell{position:relative;width:44px;height:44px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#ffffffd1;border:1px solid rgba(226,232,240,.92)}.requests-bell-icon{font-size:1.15rem}.requests-bell-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#e53e3e;color:#fff;font-size:.72rem;font-weight:700}.requests-search-card{padding:12px}.request-search-input{border-radius:14px}.branch-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:16px}.branch-tab{border:1px solid var(--border-color);border-radius:999px;padding:12px 14px;background:#fffc;color:var(--text-muted);font:inherit;font-weight:600;cursor:pointer;transition:all .2s ease}.branch-tab.active{background:linear-gradient(180deg,#2b6cb0,#2c5282);border-color:#2b6cb0;color:#fff;box-shadow:0 10px 24px #2b6cb038}.request-card-header{display:flex;gap:12px;align-items:flex-start}.request-card-body{display:flex;flex-direction:column;gap:8px;min-width:0;flex:1}.request-card-author-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.request-card-metrics{align-items:center}.author-link{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:none;padding:0;color:var(--primary-color);font:inherit;font-weight:600;cursor:pointer}.badge-urgent{background:linear-gradient(180deg,#fff5f5,#fed7d7);border-color:#feb2b2;color:#c53030}.photo-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(72px,1fr));gap:8px;margin-top:12px}.photo-tile{position:relative;aspect-ratio:1 / 1;overflow:hidden;border-radius:12px;background:#e2e8f08c}.photo-image{width:100%;height:100%;object-fit:cover}.photo-count-badge{position:absolute;right:8px;bottom:8px;border-radius:999px;padding:4px 8px;background:#0f172ab8;color:#fff;font-size:.78rem;font-weight:700}.request-actions-primary .request-primary-cta{box-shadow:0 14px 28px #2b6cb038}.request-actions-secondary{margin-top:10px}.inline-response-box{margin-top:12px;padding-top:12px;border-top:1px dashed rgba(148,163,184,.45)}.map-preview-card{overflow:hidden}.map-preview-surface{margin-top:12px;border-radius:16px;min-height:140px;padding:18px;display:flex;flex-direction:column;justify-content:space-between;background:radial-gradient(circle at 20% 20%,rgba(66,153,225,.24),transparent 34%),radial-gradient(circle at 80% 30%,rgba(72,187,120,.2),transparent 28%),linear-gradient(135deg,#e2e8f0f2,#cbd5e0b8);border:1px solid rgba(226,232,240,.96)}.map-preview-label{font-size:1rem;font-weight:700;color:var(--text-main)}.map-preview-note{color:var(--text-muted);font-size:.92rem;line-height:1.45;max-width:300px}.lost-found-card{border-color:#f6ad5566}.compact-preview{background:#ffffff8c;border-radius:12px;padding:12px;border:1px solid rgba(226,232,240,.9)}.skeleton-block{pointer-events:none}.skeleton-line{height:12px;border-radius:999px;background:linear-gradient(90deg,#e2e8f0d9,#f1f5f9f2,#e2e8f0d9);background-size:200% 100%;animation:shimmer 1.2s linear infinite}.skeleton-line+.skeleton-line{margin-top:10px}.skeleton-line-title{width:58%}.skeleton-line-meta{width:42%}.button-row,.badge-row{display:flex;gap:10px;flex-wrap:wrap}.badge{display:inline-flex;align-items:center;border:1px solid var(--border-color);border-radius:999px;padding:6px 10px;font-size:.8rem;color:var(--text-muted);background:#f8fafc}.distance-pill{background:#edf2f7;color:#2b6cb0}.rating-row,.profile-hero-rating{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.rating-stars{color:#d69e2e;letter-spacing:.04em}.rating-value{font-weight:700;color:var(--text-main)}.avatar-circle{width:64px;height:64px;border-radius:999px;background:linear-gradient(180deg,#e2e8f0,#cbd5e0);color:#2d3748;display:inline-flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:700;overflow:hidden;flex-shrink:0;border:1px solid rgba(148,163,184,.35)}.avatar-image{width:100%;height:100%;object-fit:cover}.reaction-row{justify-content:flex-start}.reaction-button{width:auto;min-width:88px}.reaction-button.active{background:linear-gradient(180deg,#ebf8ff,#bee3f8);border-color:#90cdf4;color:#2b6cb0}.overlay-root{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50}.overlay-root.active{pointer-events:auto}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;padding:20px}.modal-shell{width:100%;max-width:480px}.modal-card{margin-bottom:0;box-shadow:0 16px 40px #0f172a38}.meta{display:block;margin-top:10px;color:var(--text-muted)}.subview-header{display:flex;justify-content:flex-start;margin-bottom:12px}.subview-back{width:auto;padding:10px 14px}.subview-note{color:var(--text-muted);font-size:.9rem;line-height:1.4;margin-bottom:12px}.section-heading{margin:8px 0 12px;color:var(--text-muted);font-size:.82rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes riseIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (prefers-reduced-motion: reduce){.view,.view.active>*,.button,.button.bookmark-button,.skeleton-line,.upload-progress-fill{animation:none!important;transition:none!important}.upload-progress-fill{transform:translate(0);width:100%}}.family-note-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.family-note{color:var(--text-muted);font-size:.92rem;line-height:1.4}.family-hero-card,.family-section-card,.family-compose-card{animation:riseIn .22s ease}.family-hero-card{background:linear-gradient(180deg,#fffffffa,#ecf4ffeb)}.family-primary-cta{width:100%;margin-top:14px}.family-compose-card{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid rgba(15,23,42,.08)}.family-member-card{background:#ffffffb8}.family-member-header{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start}.profile-summary-list{display:flex;flex-direction:column;gap:8px;margin:12px 0 16px}.profile-hero-card{background:linear-gradient(180deg,#fffffffa,#edf2f7e6)}.profile-hero-header{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px}.profile-summary-row{color:var(--text-main);font-size:.95rem;line-height:1.4}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-muted);text-align:center}.empty-state i{font-size:3rem;margin-bottom:12px;opacity:.5}.category-filter-section{margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-left:-20px;margin-right:-20px;padding:0 20px}.chip-row{display:flex;gap:8px;padding-bottom:4px}.chip{flex-shrink:0;background:var(--surface-color);border:1px solid var(--border-color);border-radius:999px;padding:6px 16px;font-size:.88rem;color:var(--text-muted);cursor:pointer;transition:all .2s ease;white-space:nowrap}.chip.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 2px 4px #2b6cb033}.chip:not(.active):hover{border-color:var(--text-muted)}.chat-hero-card,.chat-context-card,.chat-participant-card,.chat-input-card{animation:riseIn .22s ease}.chat-list-card{width:100%;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:start;border:1px solid var(--border-color);border-radius:22px;padding:14px 16px;background:#ffffffd1;color:inherit;text-align:left;box-shadow:var(--card-shadow)}.chat-card-left,.chat-card-center,.chat-card-right{display:flex;flex-direction:column;gap:6px}.chat-card-right{align-items:flex-end}.chat-context-line{margin:0;font-size:.84rem;color:var(--text-muted)}.chat-unread-badge{min-width:24px;padding:4px 8px;border-radius:999px;background:linear-gradient(135deg,#ff5d7d,#ff7a45);color:#fff;font-size:.78rem;font-weight:700;text-align:center}.chat-participant-row,.chat-context-top{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.chat-context-preview{width:56px;height:56px;border-radius:18px;background:#ffffffb8;display:grid;place-items:center;overflow:hidden}.chat-context-image{width:100%;height:100%;object-fit:cover}.chat-context-placeholder{font-size:1.4rem}.chat-messages{display:flex;flex-direction:column;gap:10px}.chat-bubble-row{display:flex}.chat-bubble-row.own{justify-content:flex-end}.chat-bubble-row.peer{justify-content:flex-start}.chat-bubble{max-width:78%;border-radius:22px;padding:12px 14px;display:flex;flex-direction:column;gap:6px}.chat-bubble.own{background:linear-gradient(135deg,#4c76ff33,#6893ff1f);border:1px solid rgba(111,150,255,.24)}.chat-bubble.peer{background:#ffffffb8;border:1px solid rgba(15,23,42,.06)}.chat-bubble-text,.chat-bubble-time{margin:0}.chat-bubble-time{color:var(--text-muted)}.chat-input-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:end}.chat-textarea{min-height:56px}
