/* Gutsphere Design System — CSS v2 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --coral:#EF5350;--coral-glow:rgba(239,83,80,.07);--coral-light:rgba(239,83,80,.14);
  --white:#FFFFFF;--sand:#F5EEE8;--sand-light:#FAF6F2;--warm-cream:#FFFAF7;
  --border:#E7E0DA;--border-hover:#D4CCC5;
  --text-primary:#1C1917;--text-secondary:#57534E;--text-muted:#A8A29E;--text-hint:#C4BBB5;
  --green:#2E7D32;
  --font-d:'Inter',-apple-system,'SF Pro Display',sans-serif;
  --font-b:'DM Sans',-apple-system,sans-serif;
  --page-px:24px;--safe-bottom:32px;
  --ease-out:cubic-bezier(.4,0,.2,1);--ease-bounce:cubic-bezier(.34,1.56,.64,1);
}
html,body{font-family:var(--font-b);background:var(--sand);color:var(--text-primary);overflow:hidden;height:100dvh;-webkit-font-smoothing:antialiased}

/* Shell */
.shell{width:100%;max-width:430px;height:100dvh;margin:0 auto;position:relative;overflow:hidden;background:linear-gradient(180deg,var(--white) 0%,var(--warm-cream) 100%);display:flex;flex-direction:column}

/* Header */
.header{flex-shrink:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);padding:10px var(--page-px) 10px;border-bottom:1px solid var(--border)}
.header-status{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:600;color:var(--text-primary);margin-bottom:8px;padding:0 2px}
.header-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.header-title{flex:1;text-align:center;font-family:var(--font-d);font-size:17px;font-weight:600;letter-spacing:-.02em;color:var(--text-primary)}
.header-icon{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--white);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .2s,transform .15s;position:relative;flex-shrink:0;color:var(--text-secondary)}
.header-icon:active{transform:scale(.92)}
.header-icon svg{width:18px;height:18px}
.badge{position:absolute;top:-3px;right:-3px;min-width:16px;height:16px;border-radius:8px;background:var(--coral);color:var(--white);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--white)}
.header-left{min-width:36px}
.header-right{display:flex;align-items:center;gap:8px;min-width:36px;justify-content:flex-end}

/* Avatar */
.avatar-sm{width:36px;height:36px;border-radius:50%;background:var(--coral-glow);border:1.5px solid var(--coral-light);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--coral);cursor:pointer;transition:transform .15s}
.avatar-sm:active{transform:scale(.92)}
.avatar-lg{width:52px;height:52px;border-radius:16px;background:var(--coral-glow);border:1.5px solid var(--coral-light);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:var(--coral);flex-shrink:0}

/* Content */
.content{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding-bottom:24px}
.page{padding:var(--page-px)}
.page-title{font-family:var(--font-d);font-size:26px;font-weight:700;letter-spacing:-.025em;color:var(--text-primary);line-height:1.15}
.page-subtitle{font-size:14px;color:var(--text-secondary);margin-top:4px;line-height:1.45}

/* Cards */
.card{background:var(--white);border-radius:16px;padding:16px;margin-bottom:10px;border:1px solid var(--border);transition:border-color .3s,box-shadow .3s,transform .2s}
.card.interactive{cursor:pointer}
.card.interactive:hover{border-color:var(--border-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.05)}
.card.interactive:active{transform:scale(.985)}
.card.hl{border-color:var(--coral);box-shadow:0 0 0 3px rgba(239,83,80,.12)}
.card.coral-fill{background:var(--coral);border-color:var(--coral);color:var(--white)}
.card.dark{background:var(--text-primary);border-color:var(--text-primary);color:var(--white)}
.card.coral-glow-bg{background:var(--coral-glow);border-color:var(--coral-light)}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card-title{font-size:14px;font-weight:700;color:var(--text-primary)}
.card-subtitle{font-size:13px;color:var(--text-secondary);margin-top:4px;line-height:1.4}
.card.dark .card-title,.card.coral-fill .card-title{color:var(--white)}
.card.dark .card-subtitle{color:rgba(255,255,255,.6)}
.card.coral-fill .card-subtitle{color:rgba(255,255,255,.85)}

/* Chips */
.chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;white-space:nowrap}
.chip.coral{background:var(--coral-glow);color:var(--coral)}
.chip.amber{background:#FEF3C7;color:#92400E}
.chip.green{background:#D1FAE5;color:#065F46}
.chip.sky{background:rgba(56,189,248,.12);color:#0369A1}

/* Rows */
.row{display:flex;align-items:center;gap:12px;padding:10px 4px;border-radius:12px;cursor:pointer;transition:background .12s}
.row:hover{background:var(--sand-light)}
.row:active{background:var(--sand)}
.row-icon{width:40px;height:40px;border-radius:12px;background:var(--sand-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary)}
.row-icon svg{width:18px;height:18px}
.row-icon.coral-bg{background:var(--coral-glow);color:var(--coral)}
.row-icon.green-bg{background:#D1FAE5;color:var(--green)}
.row-icon.amber-bg{background:#FEF3C7;color:#92400E}
.row-icon.sky-bg{background:rgba(56,189,248,.12);color:#0369A1}
.row-body{flex:1;min-width:0}
.row-title{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.row-chevron{color:var(--text-hint);flex-shrink:0}
.row-chevron svg{width:16px;height:16px}
.row-meta{font-size:11px;color:var(--text-hint);font-weight:500;flex-shrink:0}

/* Segments */
.segments{display:flex;gap:6px;overflow-x:auto;padding:0 0 8px;margin-bottom:8px;scrollbar-width:none;position:relative;-webkit-mask-image:linear-gradient(to right, black 85%, transparent 100%);mask-image:linear-gradient(to right, black 85%, transparent 100%)}
.segments::-webkit-scrollbar{display:none}
.segments.scrolled-end{-webkit-mask-image:none;mask-image:none}
.segments.scrolled-mid{-webkit-mask-image:linear-gradient(to right, transparent 0%, black 5%, black 85%, transparent 100%);mask-image:linear-gradient(to right, transparent 0%, black 5%, black 85%, transparent 100%)}
.seg{padding:8px 14px;border-radius:20px;font-size:13px;font-weight:500;white-space:nowrap;cursor:pointer;transition:background .2s,color .2s;border:none;background:var(--sand-light);color:var(--text-secondary);font-family:var(--font-b)}
.seg:hover{background:var(--sand)}
.seg.active{background:var(--coral);color:var(--white);font-weight:600}

/* Sub-segment pills (nested inside a panel) — subtler than top-level */
.seg-panel .seg.active{background:var(--coral-glow);color:var(--coral)}

/* Bottom Nav */
.bottom-nav{flex-shrink:0;z-index:20;background:rgba(255,255,255,.95);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);padding:4px 6px 8px;border-top:.5px solid rgba(0,0,0,.08)}
.bottom-nav-inner{display:grid;grid-template-columns:repeat(5,1fr);gap:2px}
.nav-tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 6px 4px;cursor:pointer;border:none;background:transparent;transition:background .25s,color .2s,transform .15s,box-shadow .25s;color:#78716C;font-family:var(--font-b);border-radius:16px}
.nav-tab:active{transform:scale(.92)}
.nav-tab svg{width:22px;height:22px;stroke-width:1.8}
.nav-tab .nav-label{font-size:10px;font-weight:600}
.nav-tab.active{background:rgba(245,238,232,.85);color:var(--coral);box-shadow:0 1px 4px rgba(0,0,0,.04),inset 0 1px 0 rgba(255,255,255,.7)}
.nav-tab.active svg{stroke-width:2.2}
.nav-tab.active .nav-label{font-weight:700}

/* FAB */
.fab{position:absolute;bottom:72px;right:20px;z-index:20;width:52px;height:52px;border-radius:50%;background:var(--coral);color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(239,83,80,.35),0 2px 6px rgba(0,0,0,.1);transition:transform .25s var(--ease-bounce)}
.fab:hover{transform:scale(1.06)}
.fab:active{transform:scale(.9)}
.fab svg{width:24px;height:24px;stroke-width:2.2}

/* Sheet */
.sheet-overlay{position:absolute;inset:0;z-index:30;background:rgba(28,25,23,.3);backdrop-filter:blur(2px);display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .25s ease}
.sheet-overlay.open{opacity:1;pointer-events:auto}
.sheet-panel{width:100%;background:var(--white);border-radius:24px 24px 0 0;border-top:1px solid var(--border);padding:12px var(--page-px) var(--safe-bottom);box-shadow:0 -8px 40px rgba(0,0,0,.12);transform:translateY(100%);transition:transform .35s var(--ease-out);max-height:80vh;overflow-y:auto}
.sheet-overlay.open .sheet-panel{transform:translateY(0)}
.sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 16px}
.sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sheet-title{font-family:var(--font-d);font-size:18px;font-weight:600;color:var(--text-primary)}

/* Buttons */
.btn{width:100%;padding:14px;border-radius:16px;background:var(--coral);color:var(--white);font-family:var(--font-b);font-size:15px;font-weight:600;border:none;cursor:pointer;transition:transform .15s;text-align:center}
.btn:active{transform:scale(.97)}
.btn-outline{background:var(--white);color:var(--coral);border:1.5px solid var(--coral)}
.btn-sm{padding:8px 16px;font-size:13px;width:auto;border-radius:20px}

/* Group Labels */
.group-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-hint);margin-bottom:8px;margin-top:16px;padding:0 2px}
.group-label:first-child{margin-top:0}

/* Quick Add Grid */
.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.quick-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:14px 8px;border-radius:16px;border:1px solid var(--border);background:var(--white);cursor:pointer;transition:border-color .2s,transform .15s,background .15s}
.quick-item:hover{border-color:var(--coral-light);background:var(--coral-glow)}
.quick-item:active{transform:scale(.95)}
.quick-item .qi-icon{width:40px;height:40px;border-radius:12px;background:var(--sand-light);display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}
.quick-item .qi-icon svg{width:20px;height:20px}
.quick-item .qi-label{font-size:11px;font-weight:500;color:var(--text-secondary);text-align:center}

/* Guide List (Chat) */
.guide-row{display:flex;align-items:center;gap:12px;padding:12px;border-radius:14px;cursor:pointer;transition:background .12s;margin-bottom:2px}
.guide-row:hover{background:var(--sand-light)}
.guide-row:active{background:var(--sand)}
.guide-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.guide-avatar svg{width:20px;height:20px}
.guide-avatar.neutral{background:var(--sand-light);color:var(--text-secondary)}
.guide-avatar.coral{background:var(--coral-glow);color:var(--coral)}
.guide-avatar.green{background:#D1FAE5;color:var(--green)}
.guide-avatar.sky{background:rgba(56,189,248,.12);color:#0369A1}
.guide-avatar.amber{background:#FEF3C7;color:#92400E}
.guide-avatar.purple{background:rgba(139,92,246,.1);color:#7C3AED}
.guide-avatar.rose{background:rgba(244,63,94,.08);color:#E11D48}
.guide-body{flex:1;min-width:0}
.guide-name{font-size:14px;font-weight:600;color:var(--text-primary)}
.guide-desc{font-size:12px;color:var(--text-muted);margin-top:2px;line-height:1.35}

/* Chat thread */
.prompt-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.prompt-chip{padding:8px 12px;border-radius:20px;font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--sand-light);border:1px solid var(--border);cursor:pointer;transition:background .15s,border-color .15s}
.prompt-chip:hover{background:var(--coral-glow);border-color:var(--coral-light);color:var(--coral)}
.chat-bubbles{display:flex;flex-direction:column;gap:10px}
.bubble{max-width:82%;padding:12px 16px;border-radius:20px;font-size:14px;line-height:1.45}
.bubble.user{align-self:flex-end;background:var(--coral);color:var(--white);border-bottom-right-radius:6px}
.bubble.assistant{align-self:flex-start;background:var(--white);color:var(--text-secondary);border:1px solid var(--border);border-bottom-left-radius:6px}
.chat-input-bar{display:flex;align-items:center;gap:8px;padding:6px 6px 6px 14px;border-radius:24px;border:1px solid var(--border);background:var(--white);margin-top:16px}
.chat-input-bar input{flex:1;border:none;outline:none;font-family:var(--font-b);font-size:14px;color:var(--text-primary);background:transparent}
.chat-input-bar input::placeholder{color:var(--text-hint)}
.chat-send{width:34px;height:34px;border-radius:50%;background:var(--coral);color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s}
.chat-send:active{transform:scale(.9)}
.chat-send svg{width:16px;height:16px}

/* Detail grid / info / question */
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px}
.detail-cell{padding:12px;border-radius:12px;background:var(--sand-light)}
.detail-cell-label{font-size:11px;font-weight:500;color:var(--text-muted)}
.detail-cell-value{font-size:14px;font-weight:600;color:var(--text-primary);margin-top:4px}
.info-box{padding:12px 14px;border-radius:12px;font-size:13px;line-height:1.45;margin-top:12px}
.info-box.amber{background:#FEF3C7;color:#92400E}
.info-box.coral-soft{background:var(--coral-glow);color:var(--coral)}
.question-item{padding:12px 14px;border-radius:12px;background:var(--sand-light);font-size:14px;color:var(--text-secondary);line-height:1.4}
.question-item+.question-item{margin-top:8px}
.placeholder{padding:20px;border-radius:16px;background:var(--sand-light);color:var(--text-muted);font-size:13px;text-align:center;line-height:1.5}

/* Profile */
.profile-header{display:flex;align-items:center;gap:14px}
.profile-name{font-family:var(--font-d);font-size:18px;font-weight:600;color:var(--text-primary)}
.profile-desc{font-size:13px;color:var(--text-muted);margin-top:2px}

/* Today feed cards */
.feed-card{background:transparent;border-radius:12px;padding:10px 8px;margin-bottom:0;border:none;cursor:pointer;transition:background .12s,transform .15s;display:flex;align-items:center;gap:12px}
.feed-card:hover{background:var(--sand-light)}
.feed-card:active{transform:scale(.985)}
.feed-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--sand-light);color:var(--text-secondary)}
.feed-icon svg{width:18px;height:18px}
.feed-body{flex:1;min-width:0}
.feed-title{font-size:13px;font-weight:600;color:var(--text-primary)}
.feed-subtitle{font-size:12px;color:var(--text-muted);margin-top:2px}

/* State pills */
.state-bar{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.state-pill{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:8px;font-size:11px;font-weight:500;background:var(--sand-light);color:var(--text-secondary);border:1px solid var(--border)}
.state-pill svg{width:12px;height:12px}
.state-pill.urgent{background:var(--coral-glow);color:var(--coral);border-color:var(--coral-light)}

/* Confidence */
.confidence-bar{display:flex;align-items:center;gap:8px;margin-top:10px}
.confidence-track{flex:1;height:4px;border-radius:2px;background:var(--border);overflow:hidden}
.confidence-fill{height:100%;border-radius:2px;background:var(--coral);transition:width .4s ease}
.confidence-label{font-size:11px;font-weight:500;color:var(--text-muted);white-space:nowrap}

/* Utils */
.hidden{display:none!important}
.flex-between{display:flex;align-items:center;justify-content:space-between}
.mt-4{margin-top:16px}.mt-3{margin-top:12px}.mt-2{margin-top:8px}.mb-3{margin-bottom:12px}
.gap-sm{height:8px}.gap-md{height:14px}.gap-lg{height:20px}
.space-y>*+*{margin-top:4px}

/* Pattern chart placeholder */
.mini-chart{display:flex;align-items:flex-end;gap:3px;height:48px;padding:8px 0}
.mini-chart .bar{flex:1;border-radius:3px 3px 0 0;background:var(--coral-light);transition:height .4s ease;min-width:0}
.mini-chart .bar.active{background:var(--coral)}
.mini-chart .bar.muted{background:var(--border)}

/* Signal summary row */
.signal-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:10px;background:var(--sand-light);margin-bottom:6px}
.signal-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.signal-dot.coral{background:var(--coral)}
.signal-dot.amber{background:#F59E0B}
.signal-dot.green{background:var(--green)}
.signal-dot.muted{background:var(--text-hint)}
.signal-label{font-size:13px;color:var(--text-secondary);flex:1}
.signal-value{font-size:13px;font-weight:600;color:var(--text-primary)}

/* Profile care context */
.care-context-bar{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.care-tag{display:inline-flex;align-items:center;gap:4px;padding:5px 10px;border-radius:8px;font-size:11px;font-weight:500;border:1px solid var(--border);background:var(--white);color:var(--text-secondary)}
.care-tag svg{width:12px;height:12px}
.care-tag.active-tag{border-color:var(--coral-light);background:var(--coral-glow);color:var(--coral)}

/* Notification items */
.notif-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:14px;cursor:pointer;transition:background .12s;margin-bottom:2px;position:relative}
.notif-item:hover{background:var(--sand-light)}
.notif-item:active{background:var(--sand)}
.notif-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--sand-light);color:var(--text-secondary)}
.notif-icon svg{width:18px;height:18px}
.notif-body{flex:1;min-width:0}
.notif-title{font-size:14px;font-weight:500;color:var(--text-primary)}
.notif-sub{font-size:12px;color:var(--text-muted);margin-top:2px;line-height:1.35}
.notif-time{font-size:11px;color:var(--text-hint);margin-top:4px}
.notif-unread{position:absolute;top:14px;left:6px;width:6px;height:6px;border-radius:50%;background:var(--coral)}
.notif-urgent{border-left:3px solid var(--coral);padding-left:9px}
.time-group{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-hint);padding:12px 12px 6px;margin-top:4px}

/* Guided exercise preview */
.guided-card{display:flex;align-items:center;gap:14px;padding:14px;border-radius:14px;border:1px solid var(--border);background:var(--white);cursor:pointer;transition:border-color .2s,transform .15s;margin-bottom:8px}
.guided-card:hover{border-color:var(--coral-light);transform:translateY(-1px)}
.guided-card:active{transform:scale(.985)}
.guided-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--sand-light);color:var(--text-secondary)}
.guided-icon svg{width:22px;height:22px}
.guided-body{flex:1;min-width:0}
.guided-name{font-size:14px;font-weight:600;color:var(--text-primary)}
.guided-meta{font-size:12px;color:var(--text-muted);margin-top:2px}
.guided-tag{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:600;background:var(--sand-light);color:var(--text-muted);margin-top:6px}

/* Flare banner */
.flare-banner{background:linear-gradient(135deg,#FEF2F2 0%,#FFF7ED 100%);border:1.5px solid #FECACA;border-radius:16px;padding:16px;margin-bottom:10px}
.flare-banner .card-title{color:#DC2626}
.flare-banner .card-subtitle{color:#92400E}

/* Visit prep progress */
.prep-progress{display:flex;gap:4px;margin:12px 0 4px}
.prep-step{flex:1;height:4px;border-radius:2px;background:var(--border)}
.prep-step.done{background:var(--coral)}
.prep-step.active{background:var(--coral-light)}
.prep-label{font-size:11px;color:var(--text-muted);margin-top:4px}

.checklist-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;margin-bottom:6px;cursor:pointer;transition:background .12s}
.checklist-item:hover{background:var(--sand-light)}
.check-box{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s,border-color .15s}
.check-box.checked{background:var(--coral);border-color:var(--coral)}
.check-box.checked svg{stroke:#fff}
.check-box svg{width:14px;height:14px;stroke:transparent;stroke-width:2.5}
.check-label{font-size:13px;color:var(--text-secondary);flex:1}
.check-label.done{text-decoration:line-through;color:var(--text-hint)}

/* Clinical timeline */
.timeline-item{display:flex;gap:12px;padding:4px 0;position:relative}
.timeline-dot-col{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0}
.timeline-dot{width:10px;height:10px;border-radius:50%;border:2px solid var(--border);background:var(--white);z-index:1}
.timeline-dot.active{border-color:var(--coral);background:var(--coral)}
.timeline-dot.done{border-color:var(--green);background:var(--green)}
.timeline-line{width:2px;flex:1;background:var(--border);margin:2px 0}
.timeline-body{flex:1;padding-bottom:16px}
.timeline-title{font-size:13px;font-weight:600;color:var(--text-primary)}
.timeline-sub{font-size:12px;color:var(--text-muted);margin-top:2px}

/* Report card (repeated from patterns for care) */
.report-card{background:var(--white);border:1.5px solid var(--border);border-radius:16px;padding:16px;margin-bottom:10px;cursor:pointer;transition:border-color .2s,transform .15s,box-shadow .15s}
.report-card:hover{border-color:var(--coral-light);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.05)}
.report-card:active{transform:scale(.985)}
.report-card .report-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}
.report-ready{background:#D1FAE5;color:#065F46}
.report-draft{background:#FEF3C7;color:#92400E}

/* Contributing factors */
.factor-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;background:var(--sand-light);margin-bottom:6px}
.factor-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.factor-icon svg{width:14px;height:14px}
.factor-body{flex:1;min-width:0}
.factor-name{font-size:13px;font-weight:500;color:var(--text-primary)}
.factor-strength{font-size:11px;color:var(--text-muted);margin-top:1px}
.factor-bar{width:48px;height:4px;border-radius:2px;background:var(--border);overflow:hidden;flex-shrink:0}
.factor-bar-fill{height:100%;border-radius:2px}

/* Page transition */
.screen{transition:opacity .25s ease,transform .25s ease}
.screen.entering{animation:screenIn .3s ease forwards}
@keyframes screenIn{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}

/* FAB rotation */
.fab.open svg{transform:rotate(45deg);transition:transform .25s var(--ease-bounce)}
.fab svg{transition:transform .25s var(--ease-bounce)}

/* List stagger helper (applied via JS) */
.stagger-item{opacity:0;transform:translateY(8px);transition:opacity .3s ease,transform .3s ease}
.stagger-item.visible{opacity:1;transform:translateY(0)}

/* Scroll reveal */
.reveal{opacity:0;transform:translateY(12px);transition:opacity .4s ease,transform .4s ease}
.reveal.shown{opacity:1;transform:translateY(0)}

/* Card press feedback (enhanced) */
.feed-card:active,.guided-card:active,.report-card:active,.notif-item:active{transform:scale(.975)!important}

/* Animations */
@keyframes fadeInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeInUp .35s ease forwards}
.anim-1{animation-delay:.04s;opacity:0}.anim-2{animation-delay:.08s;opacity:0}.anim-3{animation-delay:.12s;opacity:0}
.anim-4{animation-delay:.16s;opacity:0}.anim-5{animation-delay:.2s;opacity:0}.anim-6{animation-delay:.24s;opacity:0}
.anim-7{animation-delay:.28s;opacity:0}.anim-8{animation-delay:.32s;opacity:0}

/* ===== PHASE 9: FINAL POLISH ===== */

/* iOS-style status bar */
.header-status{
  font-family:var(--font-d);
  letter-spacing:.01em;
}
.header-status .status-time{font-weight:600;font-size:15px}
.header-status .status-icons{display:flex;align-items:center;gap:4px}
.header-status .status-icons svg{width:14px;height:14px}

/* Touch target enforcement: min 44px */
.row{min-height:48px}
.nav-tab{min-height:44px;min-width:44px}
.header-icon{min-width:36px;min-height:36px}
.seg{min-height:36px}
.quick-item{min-height:72px}
.guide-row{min-height:56px}
.checklist-item{min-height:44px}
.feed-card{min-height:56px}
.notif-item{min-height:56px}
.guided-card{min-height:64px}

/* Empty state */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center}
.empty-state-icon{width:48px;height:48px;border-radius:16px;background:var(--sand-light);display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:var(--text-hint)}
.empty-state-icon svg{width:24px;height:24px}
.empty-state-title{font-family:var(--font-d);font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}
.empty-state-desc{font-size:13px;color:var(--text-muted);line-height:1.45;max-width:260px}

/* Typography audit — tighter section titles in pages */
.page-title{margin-bottom:0}
.page-subtitle{margin-bottom:0}

/* Card inner spacing consistency */
.card .card-title+.card-subtitle{margin-top:3px}
.card .space-y>*+*{margin-top:2px}

/* Better segment spacing after subtitle */
.page>.segments:first-of-type{margin-top:0}

/* Bottom safe area: proper home indicator space */
.bottom-nav{padding-bottom:max(22px,env(safe-area-inset-bottom))}

/* Frosted header — slightly more opaque on scroll */
.header{transition:background .2s ease}

/* Smooth scrollbar (desktop preview) */
.content{scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.content::-webkit-scrollbar{width:4px}
.content::-webkit-scrollbar-track{background:transparent}
.content::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}

/* Row separator: very subtle bottom border for dense lists */
.card .row+.row{border-top:1px solid rgba(0,0,0,.03)}

/* Feed card left accent bar */
.feed-card.accent-coral{border-left:3px solid var(--coral);padding-left:13px}
.feed-card.accent-amber{border-left:3px solid #F59E0B;padding-left:13px}
.feed-card.accent-green{border-left:3px solid var(--green);padding-left:13px}
.feed-card.accent-sky{border-left:3px solid #0EA5E9;padding-left:13px}

/* Placeholder image-like area (for future chart/image slots) */
.chart-placeholder{width:100%;height:120px;border-radius:12px;background:linear-gradient(135deg,var(--sand-light) 0%,var(--sand) 100%);display:flex;align-items:center;justify-content:center;color:var(--text-hint);font-size:12px;margin-top:8px}

/* Print-friendly (for Visit Prep export) */
@media print{
  .bottom-nav,.fab,.header,.sheet-overlay{display:none!important}
  .shell{max-width:100%;height:auto;overflow:visible}
  .content{overflow:visible;padding-bottom:0}
  .card{break-inside:avoid;box-shadow:none;border:1px solid #ddd}
}


