/* ============================================================================
   STAND EASY - Veteran app (mobile) layout + demo shell
   ============================================================================ */

/* ---------- Demo shell (scaffolding, not the product) ---------- */
.demo-bar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: var(--space-4); flex-wrap: wrap;
  padding: var(--space-3) var(--space-5);
  background: rgba(251,247,240,.85); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-border);
}
.demo-brand { display: flex; align-items: center; gap: var(--space-2); font-weight: 700; }
.demo-brand .mark { width: 30px; height: 30px; border-radius: 9px; background: var(--color-primary); color: #fff; display: grid; place-items: center; }
.demo-brand .mark svg { width: 18px; height: 18px; }
.demo-brand small { color: var(--color-text-tertiary); font-weight: 600; letter-spacing: .03em; text-transform: uppercase; font-size: 10px; }
.seg { display: inline-flex; background: var(--color-surface-sunken); border-radius: var(--radius-pill); padding: 4px; gap: 2px; }
.seg button { border: none; background: none; cursor: pointer; min-height: 38px; padding: 0 var(--space-4); border-radius: var(--radius-pill); font-weight: 600; font-size: var(--fs-caption); color: var(--color-text-secondary); }
.seg button.is-on { background: var(--color-surface); color: var(--color-text); box-shadow: var(--shadow-sm); }
.demo-actions { margin-left: auto; display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; }

/* ---------- Stage ---------- */
.stage { min-height: calc(100vh - 64px); padding: var(--space-7) var(--space-5) var(--space-9); }
.stage-app { display: flex; flex-direction: column; align-items: center; gap: var(--space-5);
  background:
    radial-gradient(60% 50% at 50% 0%, #F8E7D5 0%, rgba(248,231,213,0) 70%),
    var(--color-bg);
}

/* ---------- Phone frame ---------- */
.phone {
  width: 390px; max-width: 100%; height: 844px; max-height: calc(100vh - 130px);
  background: var(--color-bg); border-radius: 46px; padding: 0;
  box-shadow: 0 0 0 11px #20262B, 0 0 0 13px #2c343a, var(--shadow-lg);
  position: relative; overflow: hidden; display: flex; flex-direction: column;
}
.phone-statusbar { height: 44px; flex: none; display: flex; align-items: center; justify-content: space-between; padding: 0 26px; font-size: 13px; font-weight: 700; color: var(--color-text); }
.phone-statusbar .notch { position: absolute; left: 50%; transform: translateX(-50%); top: 12px; width: 120px; height: 26px; background: #20262B; border-radius: 0 0 16px 16px; }
.phone-statusbar .sb-icons { display: flex; gap: 6px; align-items: center; }
.phone-statusbar .sb-icons svg { width: 17px; height: 17px; }
.phone-screen { flex: 1; overflow-y: auto; overflow-x: hidden; position: relative; scrollbar-width: none; }
.phone-screen::-webkit-scrollbar { display: none; }
.phone-nav { flex: none; }

.app-view { padding: var(--space-4) var(--space-5) var(--space-7); min-height: 100%; }
.app-view-flush { padding: 0 0 var(--space-7); }

/* ---------- App header ---------- */
.app-head { display: flex; align-items: center; justify-content: space-between; padding: var(--space-2) 0 var(--space-4); }
.app-head .greet-eyebrow { font-size: var(--fs-caption); color: var(--color-text-secondary); font-weight: 600; }
.app-head .greet-name { font-family: var(--font-display); font-size: var(--fs-h2); }
.icon-btn { width: 42px; height: 42px; border-radius: var(--radius-pill); border: 1px solid var(--color-border); background: var(--color-surface); display: grid; place-items: center; cursor: pointer; color: var(--color-text); position: relative; }
.icon-btn svg { width: 22px; height: 22px; }
.icon-btn .dot-badge { position: absolute; top: 6px; right: 7px; width: 9px; height: 9px; border-radius: 50%; background: var(--color-danger); border: 2px solid var(--color-surface); }

/* ---------- Ritual cards (Reveille / Stand Down) ---------- */
.ritual { display: flex; align-items: center; gap: var(--space-4); }
.ritual .ritual-ico { width: 56px; height: 56px; border-radius: var(--radius-lg); display: grid; place-items: center; flex: none; }
.ritual .ritual-ico svg { width: 30px; height: 30px; }
.ritual-reveille .ritual-ico { background: rgba(255,255,255,.18); color: #fff; }
.ritual-eyebrow { font-size: var(--fs-label); letter-spacing: .06em; text-transform: uppercase; font-weight: 700; opacity: .85; }

/* ---------- Crisis access (always reachable) ---------- */
.crisis-fab { display: flex; align-items: center; gap: var(--space-2); }
.help-pill {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: var(--radius-pill);
  background: var(--color-danger-soft); color: var(--color-danger-text); border: 1px solid #EBC9C2;
  font-weight: 700; font-size: var(--fs-caption); cursor: pointer; min-height: 40px;
}
.help-pill svg { width: 18px; height: 18px; }

/* ---------- Onboarding ---------- */
.onb { min-height: 100%; display: flex; flex-direction: column; padding: var(--space-6) var(--space-5) var(--space-6); }
.onb-art { flex: 1; display: grid; place-items: center; min-height: 240px; }
.onb-blob { width: 200px; height: 200px; border-radius: 42% 58% 56% 44% / 50% 44% 56% 50%; display: grid; place-items: center; background: linear-gradient(140deg, #F2C29E, #E8915B); color: #fff; animation: breathe 6s var(--ease-calm) infinite; }
.onb-blob svg { width: 96px; height: 96px; }
@keyframes breathe { 0%,100% { transform: scale(1); } 50% { transform: scale(1.05); } }
.dots { display: flex; gap: 7px; justify-content: center; }
.dots i { width: 7px; height: 7px; border-radius: 50%; background: var(--color-border-strong); }
.dots i.on { width: 22px; border-radius: var(--radius-pill); background: var(--color-primary); }

/* ---------- Learn unit / lesson tiles ---------- */
.course-card { position: relative; overflow: hidden; color: #fff; padding: var(--space-5); border-radius: var(--radius-lg); min-height: 132px; display: flex; flex-direction: column; justify-content: space-between; cursor: pointer; }
.course-card h3 { color: #fff; font-size: var(--fs-title); font-family: var(--font-body); font-weight: 700; }
.course-card .course-meta { font-size: var(--fs-caption); opacity: .9; }
.course-card .course-ico { position: absolute; right: -10px; bottom: -10px; opacity: .22; }
.course-card .course-ico svg { width: 96px; height: 96px; }

/* ---------- Resource cards ---------- */
.res-card { display: flex; flex-direction: column; gap: var(--space-2); }
.res-card .res-top { display: flex; align-items: flex-start; justify-content: space-between; gap: var(--space-2); }
.res-actions { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-1); }
.res-call { display: inline-flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: var(--radius-pill); background: var(--color-primary-strong); color: #fff; font-weight: 600; font-size: var(--fs-caption); min-height: 42px; }
.res-call svg { width: 17px; height: 17px; }
.res-call.is-crisis { background: var(--color-danger); }
.res-call.is-ghost { background: transparent; color: var(--color-primary-strong); border: 1px solid var(--color-border-strong); }

/* ---------- Give back / volunteering ---------- */
.vol-card .vol-tagrow { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px; }

/* ---------- Slider (mood deeper layer) ---------- */
.range { width: 100%; appearance: none; height: 8px; border-radius: var(--radius-pill); background: linear-gradient(90deg, var(--mood-1), var(--mood-3), var(--mood-5)); outline: none; }
.range::-webkit-slider-thumb { appearance: none; width: 28px; height: 28px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-md); border: 3px solid var(--color-primary); cursor: pointer; }

/* ---------- caption note ---------- */
.foot-note { font-size: var(--fs-label); color: var(--color-text-tertiary); text-align: center; margin-top: var(--space-4); }

.app-caption-bar { padding: var(--space-3) var(--space-5); max-width: 420px; text-align: center; color: var(--color-text-secondary); font-size: var(--fs-caption); }
