:root {
  --coral: #ff5b4d;
  --coral-dark: #e8483d;
  --coral-soft: #fff0ed;
  --ink: #24221f;
  --muted: #8d8983;
  --line: #eeeae4;
  --paper: #fffdfa;
  --cream: #f8f5ef;
  --green: #28a982;
  --blue: #4c7df0;
  --shadow: 0 18px 60px rgba(57, 44, 35, .14);
}

* { box-sizing: border-box; }
html { background: #f3efe9; }
body { margin: 0; min-height: 100vh; color: var(--ink); font-family: Inter, "PingFang SC", "Microsoft YaHei", system-ui, sans-serif; background: linear-gradient(135deg, #f7f1ea, #f0ede7); overflow-x: hidden; }
button, input, textarea, select { font: inherit; }
button { border: 0; cursor: pointer; color: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
em { font-style: normal; }
.ambient { position: fixed; border-radius: 50%; filter: blur(10px); pointer-events: none; opacity: .55; }
.ambient-one { width: 480px; height: 480px; background: #ffd7cc; left: -180px; top: -180px; }
.ambient-two { width: 420px; height: 420px; background: #d8e7dc; right: -140px; bottom: -180px; }

.app-shell { position: relative; z-index: 1; min-height: 100vh; display: grid; grid-template-columns: minmax(360px, 540px) 430px; gap: clamp(40px, 8vw, 140px); align-items: center; justify-content: center; padding: 42px; }
.brand-panel { height: min(790px, calc(100vh - 84px)); display: flex; flex-direction: column; padding: 24px 8px; }
.brand-lockup { display: flex; align-items: center; gap: 12px; font-size: 24px; font-weight: 850; letter-spacing: -.04em; }
.brand-lockup > span:last-child { display: flex; align-items: baseline; gap: 5px; }.brand-lockup > span:last-child small { color: var(--coral); font-size: 13px; font-weight: 750; letter-spacing: .08em; }
.brand-mark { position: relative; display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; background: var(--coral); border-radius: 14px 14px 14px 5px; box-shadow: 0 10px 22px rgba(255,91,77,.3); }
.brand-mark i { position: absolute; border: 2px solid #fff; border-radius: 50%; }
.brand-mark i:nth-child(1) { width: 8px; height: 8px; }
.brand-mark i:nth-child(2) { width: 18px; height: 18px; opacity: .75; }
.brand-mark i:nth-child(3) { width: 28px; height: 28px; opacity: .38; }
.brand-copy { margin: auto 0 46px; }
.eyebrow { color: var(--coral); font-size: 12px; font-weight: 800; letter-spacing: .18em; }
.brand-copy h1 { margin: 18px 0 20px; font-size: clamp(48px, 5.3vw, 76px); line-height: 1.06; letter-spacing: -.065em; }
.brand-copy > p:last-child { max-width: 400px; color: #716d67; font-size: 18px; line-height: 1.8; }
.live-card { width: 100%; max-width: 420px; padding: 22px; border: 1px solid rgba(255,255,255,.7); border-radius: 26px; background: rgba(255,255,255,.52); backdrop-filter: blur(18px); box-shadow: 0 12px 36px rgba(60,45,35,.06); }
.live-pulse { color: #65615c; font-size: 13px; font-weight: 650; }
.live-pulse span, .pulse-dot { display: inline-block; width: 8px; height: 8px; margin-right: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 5px rgba(40,169,130,.14); }
.live-card strong { display: block; margin-top: 11px; font-size: 38px; line-height: 1; letter-spacing: -.05em; }
.live-card small { color: var(--muted); }
.live-tags { display: flex; gap: 8px; margin-top: 18px; }
.live-tags span { padding: 7px 10px; border-radius: 10px; background: #fff; font-size: 12px; }
.panel-note { margin: 22px 0 0; color: #aaa49d; font-size: 12px; letter-spacing: .08em; }

.phone-stage { width: 430px; height: min(880px, calc(100vh - 40px)); min-height: 680px; padding: 10px; border: 1px solid rgba(255,255,255,.88); border-radius: 48px; background: rgba(255,255,255,.62); box-shadow: var(--shadow); backdrop-filter: blur(22px); }
.phone-app { position: relative; height: 100%; overflow: hidden; border-radius: 39px; background: var(--paper); }
.phone-app::before { content: ""; position: absolute; z-index: 20; top: 8px; left: 50%; width: 90px; height: 24px; transform: translateX(-50%); border-radius: 20px; background: rgba(35,33,30,.94); opacity: 0; pointer-events: none; }
.topbar { position: absolute; z-index: 12; top: 0; left: 0; right: 0; height: 78px; display: flex; align-items: center; justify-content: space-between; padding: 16px 18px 8px; background: rgba(255,253,250,.92); backdrop-filter: blur(16px); }
.location-button { display: flex; align-items: center; gap: 8px; background: transparent; text-align: left; padding: 0; }
.location-button > .icon:first-child { color: var(--coral); }
.location-button span:nth-child(2) { display: flex; flex-direction: column; }
.location-button small { color: var(--muted); font-size: 10px; }
.location-button strong { margin-top: 2px; font-size: 15px; }
.tiny { width: 14px!important; height: 14px!important; color: #aaa; }
.top-actions { display: flex; gap: 7px; }
.voice-button { color: var(--coral); background: var(--coral-soft)!important; }
.icon-button { position: relative; display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 13px; background: #f6f2ed; }
.notification-button i, .nav-dot { position: absolute; width: 7px; height: 7px; border: 2px solid var(--paper); border-radius: 50%; background: var(--coral); right: 7px; top: 6px; }
.icon { display: inline-flex; width: 20px; height: 20px; }
.icon svg { width: 100%; height: 100%; fill: none; stroke: currentColor; stroke-linecap: round; stroke-linejoin: round; stroke-width: 1.9; }
.search-drawer { position: absolute; z-index: 11; top: 0; left: 0; right: 0; padding: 19px 18px 11px; background: var(--paper); transform: translateY(-100%); transition: .25s ease; }
.search-drawer.open { transform: translateY(0); }
.search-drawer label { height: 46px; display: flex; align-items: center; gap: 9px; padding: 0 12px; border-radius: 15px; background: #f3f0eb; }
.search-drawer input { min-width: 0; flex: 1; border: 0; outline: 0; background: transparent; }
.search-drawer button { padding: 5px; background: transparent; color: var(--coral); font-size: 13px; }

.page { display: none; height: 100%; padding: 82px 17px 104px; overflow-y: auto; scrollbar-width: none; }
.page::-webkit-scrollbar { display: none; }
.page.active { display: block; animation: fadeUp .28s ease both; }
@keyframes fadeUp { from { opacity: .35; transform: translateY(5px); } }
.hero-card { position: relative; min-height: 187px; overflow: hidden; display: flex; padding: 22px; border-radius: 25px; color: #fff; background: linear-gradient(135deg, #ff6a59, #f54d43 70%, #ea433b); box-shadow: 0 17px 32px rgba(235,75,63,.22); }
.hero-card::after { content: ""; position: absolute; width: 260px; height: 260px; right: -130px; top: -120px; border-radius: 50%; background: rgba(255,255,255,.07); }
.hero-copy { position: relative; z-index: 2; }
.hero-label { font-size: 11px; font-weight: 650; opacity: .82; }
.hero-copy h2 { margin: 10px 0 15px; font-size: 26px; line-height: 1.18; letter-spacing: -.04em; }
.hero-publish { display: flex; align-items: center; gap: 5px; padding: 8px 12px; border-radius: 12px; background: #fff; color: var(--coral-dark); font-size: 12px; font-weight: 750; }
.hero-publish .icon { width: 15px; height: 15px; }
.radar-visual { position: absolute; width: 160px; height: 160px; right: 2px; top: 13px; }
.radar-ring { position: absolute; top: 50%; left: 50%; border: 1px solid rgba(255,255,255,.23); border-radius: 50%; transform: translate(-50%,-50%); }
.r1 { width: 55px; height: 55px; }.r2 { width: 100px; height: 100px; }.r3 { width: 150px; height: 150px; }
.radar-center { position: absolute; top: 50%; left: 50%; width: 22px; height: 22px; transform: translate(-50%,-50%); border: 5px solid rgba(255,255,255,.28); border-radius: 50%; background: #fff; box-shadow: 0 0 18px #fff; }
.radar-center::after { content: ""; position: absolute; left: 6px; top: 6px; width: 80px; height: 1px; transform-origin: left; background: linear-gradient(90deg,rgba(255,255,255,.8),transparent); animation: sweep 4s linear infinite; }
@keyframes sweep { to { transform: rotate(360deg); } }
.radar-dot { position: absolute; display: grid; place-items: center; width: 29px; height: 29px; border-radius: 10px; background: rgba(255,255,255,.92); font-size: 14px; box-shadow: 0 5px 14px rgba(120,30,30,.18); }
.d1 { right: 8px; top: 27px; }.d2 { left: 13px; bottom: 22px; }.d3 { right: 30px; bottom: 6px; }
.quick-types { display: grid; grid-template-columns: repeat(4,1fr); gap: 6px; margin: 19px 0 25px; }
.quick-type { display: flex; flex-direction: column; align-items: center; gap: 7px; padding: 0; background: transparent; font-size: 11px; }
.quick-type em { white-space: nowrap; }
.quick-type.active em { font-weight: 750; color: var(--coral); }
.quick-icon { display: grid; place-items: center; width: 48px; height: 48px; border-radius: 17px; font-size: 21px; transition: transform .2s; }
.quick-type:active .quick-icon { transform: scale(.92); }
.quick-icon.all { color: var(--coral); background: #fff0ec; }.quick-icon.goods { background: #fff4dc; }.quick-icon.activity { background: #eaf7ee; }.quick-icon.help { background: #eaf1ff; }
.section-heading { display: flex; align-items: end; justify-content: space-between; margin-bottom: 14px; }
.section-heading h3 { margin: 0; font-size: 18px; letter-spacing: -.02em; }.section-heading p { margin: 3px 0 0; color: var(--muted); font-size: 10px; }
.section-heading.compact { margin: 25px 2px 13px; }
.view-switch { display: flex; padding: 3px; border-radius: 11px; background: #f2efeb; }
.view-switch button { display: grid; place-items: center; width: 30px; height: 28px; border-radius: 8px; background: transparent; color: #aaa; }
.view-switch button.active { background: #fff; color: var(--ink); box-shadow: 0 2px 8px rgba(30,20,15,.08); }
.view-switch .icon { width: 16px; height: 16px; }
.filter-row { display: flex; gap: 7px; margin-bottom: 12px; overflow-x: auto; scrollbar-width: none; }
.chip { flex: 0 0 auto; padding: 7px 11px; border-radius: 10px; background: #f4f1ed; color: #77726d; font-size: 11px; }
.chip.active { color: #fff; background: var(--ink); }
.broadcast-list { display: grid; gap: 12px; }
.broadcast-card { position: relative; overflow: hidden; padding: 15px; border: 1px solid var(--line); border-radius: 20px; background: #fff; box-shadow: 0 6px 20px rgba(53,42,34,.045); }
.broadcast-card:active { transform: scale(.99); }
.card-top { display: flex; align-items: center; gap: 9px; }
.avatar { display: inline-grid; flex: 0 0 auto; place-items: center; width: 36px; height: 36px; border-radius: 13px; color: #fff; font-weight: 750; }
.avatar.coral { background: linear-gradient(145deg,#ff8a73,#ef4d43); }.avatar.blue { background: linear-gradient(145deg,#7da8ff,#4672da); }.avatar.green { background: linear-gradient(145deg,#6fc7a4,#2b9671); }
.avatar.xl { width: 58px; height: 58px; border-radius: 20px; font-size: 22px; box-shadow: 0 8px 18px rgba(239,77,67,.2); }
.card-owner { min-width: 0; flex: 1; display: flex; flex-direction: column; }.card-owner strong { font-size: 12px; }.card-owner small { margin-top: 2px; color: var(--muted); font-size: 9px; }
.verified { display: inline-grid; place-items: center; width: 15px; height: 15px; border-radius: 50%; color: #fff; background: var(--blue); font-size: 9px; font-style: normal; }
.countdown { display: flex; align-items: center; gap: 4px; padding: 6px 8px; border-radius: 9px; color: var(--coral-dark); background: var(--coral-soft); font-size: 10px; font-weight: 700; }
.countdown .icon { width: 12px; height: 12px; }
.card-main { display: flex; gap: 12px; margin-top: 13px; }
.card-content { min-width: 0; flex: 1; }
.card-content h4 { margin: 0 0 6px; font-size: 16px; line-height: 1.35; letter-spacing: -.025em; }
.card-content p { margin: 0; color: #77726d; font-size: 11px; line-height: 1.55; }
.card-thumb { flex: 0 0 78px; height: 78px; display: grid; place-items: center; overflow: hidden; border-radius: 15px; font-size: 36px; }
.thumb-buns { background: radial-gradient(circle at 35% 30%,#fff9e9,#f2c981); }.thumb-mahjong { background: linear-gradient(145deg,#e1f6e8,#99d3ac); }.thumb-hike { background: linear-gradient(#d8ecff 45%,#b4d1b8 46%); }.thumb-help { background: linear-gradient(145deg,#eef2ff,#cad6ff); }
.meta-row { display: flex; align-items: center; gap: 9px; margin-top: 10px; color: #8e8983; font-size: 10px; }
.meta-row span { display: flex; align-items: center; gap: 3px; }.meta-row .icon { width: 12px; height: 12px; }
.progress-block { margin-top: 13px; }
.progress-copy { display: flex; justify-content: space-between; font-size: 10px; }.progress-copy strong { color: var(--coral); }.progress-copy span { color: var(--muted); }
.progress-track { height: 6px; overflow: hidden; margin-top: 7px; border-radius: 6px; background: #f0ede8; }.progress-track i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg,#ff806d,var(--coral)); transition: width .4s; }
.card-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 13px; padding-top: 12px; border-top: 1px solid #f3f0ec; }
.participant-stack { display: flex; align-items: center; color: var(--muted); font-size: 9px; }.participant-stack i { width: 22px; height: 22px; display: grid; place-items: center; margin-right: -5px; border: 2px solid #fff; border-radius: 50%; color: #fff; background: #aaa; font-size: 8px; font-style: normal; }.participant-stack span { margin-left: 10px; }
.join-button { padding: 8px 14px; border-radius: 11px; color: #fff; background: var(--coral); font-size: 11px; font-weight: 700; box-shadow: 0 6px 13px rgba(255,91,77,.2); }
.join-button.secondary { color: var(--ink); background: #f2efeb; box-shadow: none; }
.map-view { position: relative; display: none; height: 420px; overflow: hidden; border-radius: 23px; background: #e9eadf; }
.map-view.active { display: block; }
.map-grid { position: absolute; inset: 0; opacity: .4; background-image: linear-gradient(#cdd5ca 1px,transparent 1px),linear-gradient(90deg,#cdd5ca 1px,transparent 1px); background-size: 42px 42px; transform: rotate(18deg) scale(1.4); }
.road { position: absolute; width: 520px; height: 19px; border: 5px solid #fff; border-left: 0; border-right: 0; background: #d7d7d0; transform: rotate(-24deg); }.road-a { left: -80px; top: 130px; }.road-b { left: -40px; top: 270px; transform: rotate(31deg); }
.river { position: absolute; width: 80px; height: 520px; top: -60px; right: 58px; transform: rotate(15deg); background: rgba(135,194,215,.48); }
.map-pin { position: absolute; display: flex; align-items: center; gap: 5px; padding: 6px 9px 6px 6px; border-radius: 20px 20px 20px 6px; background: #fff; box-shadow: 0 6px 18px rgba(45,50,43,.18); }.map-pin b { display: grid; place-items: center; width: 27px; height: 27px; border-radius: 50%; background: #fff3e7; }.map-pin small { font-size: 9px; font-weight: 700; }.pin-a { left: 44px; top: 67px; }.pin-b { right: 44px; top: 197px; }.pin-c { left: 78px; bottom: 72px; }
.me-pin { position: absolute; left: 48%; top: 45%; width: 24px; height: 24px; border: 6px solid #fff; border-radius: 50%; background: var(--blue); box-shadow: 0 4px 15px rgba(76,125,240,.4); }.me-pin i { position: absolute; inset: -14px; border: 2px solid rgba(76,125,240,.25); border-radius: 50%; animation: ping 2s infinite; } @keyframes ping { 50% { transform: scale(1.3); opacity: .2; } }
.map-legend { position: absolute; left: 16px; right: 16px; bottom: 15px; padding: 13px; border-radius: 15px; background: rgba(255,255,255,.9); font-size: 11px; box-shadow: 0 5px 20px rgba(30,40,30,.1); }

.page-title { display: flex; align-items: center; justify-content: space-between; margin: 8px 2px 20px; }.page-title p { margin: 0 0 4px; color: var(--coral); font-size: 11px; font-weight: 750; }.page-title h2 { margin: 0; font-size: 24px; letter-spacing: -.04em; }.text-button { background: transparent; color: var(--coral); font-size: 11px; }
.topic-banner { position: relative; min-height: 165px; overflow: hidden; padding: 22px; border-radius: 24px; color: #fff; background: linear-gradient(135deg,#334745,#1e2f2e); }.topic-banner span { font-size: 10px; opacity: .7; }.topic-banner h3 { margin: 9px 0 14px; font-size: 21px; line-height: 1.3; }.topic-banner button { padding: 7px 12px; border-radius: 10px; background: #fff; font-size: 10px; }.topic-art i { position: absolute; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.11); font-style: normal; }.topic-art i:nth-child(1) { width: 92px; height: 92px; right: 15px; top: 21px; font-size: 43px; }.topic-art i:nth-child(2) { width: 45px; height: 45px; right: 91px; bottom: 4px; font-size: 20px; }.topic-art i:nth-child(3) { width: 38px; height: 38px; right: 4px; bottom: 2px; font-size: 17px; }
.template-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 10px; }.template-card { min-height: 128px; padding: 15px; border-radius: 19px; text-align: left; background: #f7f3ed; }.template-card:nth-child(2) { background: #edf5f1; }.template-card:nth-child(3) { background: #eef2fa; }.template-card:nth-child(4) { background: #fff0ed; }.template-card > span { font-size: 26px; }.template-card strong { display: block; margin-top: 13px; font-size: 13px; }.template-card small { display: block; margin-top: 3px; color: var(--muted); font-size: 9px; }
.people-strip { display: flex; gap: 9px; overflow-x: auto; scrollbar-width: none; }.people-strip article { min-width: 114px; padding: 14px 10px; border: 1px solid var(--line); border-radius: 18px; background: #fff; text-align: center; }.people-strip .avatar { margin: auto; }.people-strip strong { display: block; margin-top: 7px; font-size: 11px; }.people-strip small { display: block; margin: 2px 0 8px; color: var(--muted); font-size: 8px; }.people-strip button { padding: 5px 12px; border-radius: 8px; color: var(--coral); background: var(--coral-soft); font-size: 9px; }
.message-tabs { display: flex; gap: 8px; padding-bottom: 13px; border-bottom: 1px solid var(--line); }.message-tabs button { padding: 7px 11px; border-radius: 10px; color: var(--muted); background: transparent; font-size: 11px; }.message-tabs button.active { color: #fff; background: var(--ink); }
.message-list { display: grid; }.message-item { position: relative; display: flex; gap: 11px; padding: 15px 2px; border-bottom: 1px solid var(--line); }.message-icon { display: grid; flex: 0 0 auto; place-items: center; width: 43px; height: 43px; border-radius: 15px; background: var(--coral-soft); font-size: 20px; }.message-item > div { min-width: 0; flex: 1; }.message-item strong { display: block; font-size: 12px; }.message-item p { overflow: hidden; margin: 5px 0 0; color: var(--muted); font-size: 10px; text-overflow: ellipsis; white-space: nowrap; }.message-item time { color: #aaa; font-size: 8px; }.message-item.unread::after { content: ""; position: absolute; right: 3px; top: 37px; width: 7px; height: 7px; border-radius: 50%; background: var(--coral); }
.profile-hero { position: relative; margin: -82px -17px 0; padding: 102px 20px 24px; color: #fff; background: linear-gradient(145deg,#303a38,#1d2927); border-radius: 0 0 27px 27px; }.settings-button { position: absolute; right: 18px; top: 25px; display: grid; place-items: center; width: 37px; height: 37px; border-radius: 13px; color: #fff; background: rgba(255,255,255,.1); }.profile-main { display: flex; align-items: center; gap: 13px; }.profile-main h2 { margin: 0; font-size: 20px; }.profile-main p { margin: 5px 0 0; color: rgba(255,255,255,.56); font-size: 10px; }.trust-card { display: flex; align-items: end; gap: 11px; margin-top: 22px; padding: 13px 14px; border: 1px solid rgba(255,255,255,.09); border-radius: 16px; background: rgba(255,255,255,.07); }.trust-card small { display: block; color: rgba(255,255,255,.58); font-size: 8px; }.trust-card strong { font-size: 22px; }.trust-card strong em { font-size: 11px; }.trust-card > span { margin-left: auto; color: #a8e4c2; font-size: 9px; }.trust-bars { display: flex; align-items: end; gap: 3px; height: 25px; }.trust-bars i { width: 4px; border-radius: 4px; background: #62d49a; }.trust-bars i:nth-child(1){height:7px}.trust-bars i:nth-child(2){height:11px}.trust-bars i:nth-child(3){height:15px}.trust-bars i:nth-child(4){height:20px}.trust-bars i:nth-child(5){height:25px}
.stats-row { display: grid; grid-template-columns: repeat(3,1fr); padding: 20px 0; }.stats-row div { text-align: center; border-right: 1px solid var(--line); }.stats-row div:last-child { border: 0; }.stats-row strong { display: block; font-size: 18px; }.stats-row small { color: var(--muted); font-size: 9px; }
.energy-card { display: flex; align-items: center; gap: 11px; padding: 15px; border-radius: 19px; background: #fff3df; }.energy-icon { display: grid; place-items: center; width: 41px; height: 41px; border-radius: 14px; color: #f09626; background: #fff; }.energy-card > div { min-width: 0; flex: 1; }.energy-card small { color: #9e7440; font-size: 9px; }.energy-card strong { display: block; font-size: 18px; }.energy-card strong em { color: #ad8e68; font-size: 10px; }.energy-card > div > span { display: block; height: 4px; margin-top: 6px; border-radius: 4px; background: #ead7b7; }.energy-card > div > span i { display: block; height: 100%; border-radius: inherit; background: #f0a437; }.energy-card button { padding: 6px 9px; border-radius: 9px; color: #9b6f36; background: rgba(255,255,255,.65); font-size: 9px; }
.menu-list { margin-top: 13px; border-radius: 20px; background: #fff; }.menu-list button { width: 100%; display: flex; align-items: center; gap: 11px; padding: 12px 2px; border-bottom: 1px solid var(--line); background: transparent; text-align: left; }.menu-list button:last-child { border: 0; }.menu-list button > div { flex: 1; }.menu-list strong { display: block; font-size: 12px; }.menu-list small { color: var(--muted); font-size: 9px; }.menu-icon { display: grid; place-items: center; width: 39px; height: 39px; border-radius: 13px; }.menu-icon.warm{color:#e46b42;background:#fff0e8}.menu-icon.mint{color:#299873;background:#e9f8f1}.menu-icon.blue{color:#4c7df0;background:#edf2ff}.menu-icon.violet{color:#8364c8;background:#f2edff}.menu-icon .icon{width:18px;height:18px}

.bottom-nav { position: absolute; z-index: 14; left: 0; right: 0; bottom: 0; height: 78px; display: grid; grid-template-columns: repeat(5,1fr); padding: 7px 10px max(8px,env(safe-area-inset-bottom)); border-top: 1px solid rgba(224,219,212,.85); background: rgba(255,253,250,.94); backdrop-filter: blur(18px); }
.bottom-nav button { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; background: transparent; color: #aaa49e; font-size: 9px; }.bottom-nav button.active { color: var(--coral); }.bottom-nav .icon { width: 20px; height: 20px; }.publish-nav > span { display: grid; place-items: center; width: 46px; height: 42px; margin-top: -23px; border: 5px solid var(--paper); border-radius: 17px; color: #fff; background: var(--coral); box-shadow: 0 7px 18px rgba(255,91,77,.3); }.publish-nav em { color: var(--coral); }.publish-nav .icon { width: 22px; height: 22px; }.bottom-nav .nav-dot { right: 21px; top: 10px; border-color: var(--paper); }

.overlay { position: fixed; z-index: 50; inset: 0; display: flex; align-items: end; justify-content: center; padding: 20px; visibility: hidden; opacity: 0; background: rgba(28,24,21,.42); backdrop-filter: blur(7px); transition: .25s; }.overlay.open { visibility: visible; opacity: 1; }.bottom-sheet { position: relative; width: min(420px,100%); max-height: min(770px,calc(100vh - 30px)); overflow-y: auto; padding: 15px 18px 24px; border-radius: 30px 30px 24px 24px; background: var(--paper); box-shadow: 0 -20px 60px rgba(30,20,15,.2); transform: translateY(35px); transition: .3s ease; scrollbar-width: none; }.overlay.open .bottom-sheet { transform: translateY(0); }.sheet-handle { width: 42px; height: 4px; margin: 0 auto 14px; border-radius: 4px; background: #ddd7d0; }.sheet-close { position: absolute; z-index: 2; right: 17px; top: 18px; display: grid; place-items: center; width: 35px; height: 35px; border-radius: 12px; background: #f2efeb; }.sheet-close .icon { width: 17px; height: 17px; }
.detail-cover { height: 170px; display: grid; place-items: center; margin: 0 0 18px; border-radius: 22px; background: radial-gradient(circle at 30% 20%,#fff8df,#ebc06f); font-size: 80px; }.detail-owner { display: flex; align-items: center; gap: 9px; }.detail-owner > div { flex: 1; }.detail-owner strong { display: block; font-size: 12px; }.detail-owner small { color: var(--muted); font-size: 9px; }.detail-title { margin: 17px 0 8px; font-size: 23px; letter-spacing: -.04em; }.detail-description { color: #6f6a65; font-size: 12px; line-height: 1.7; }.detail-info { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin: 15px 0; }.detail-info div { padding: 11px; border-radius: 13px; background: #f6f3ee; }.detail-info small { display: block; color: var(--muted); font-size: 8px; }.detail-info strong { display: block; margin-top: 5px; font-size: 11px; }.detail-action { width: 100%; margin-top: 16px; padding: 14px; border-radius: 15px; color: #fff; background: var(--coral); font-weight: 750; box-shadow: 0 8px 20px rgba(255,91,77,.23); }
.publish-sheet { overflow: hidden; padding-bottom: 0; }.publish-sheet header { display: grid; grid-template-columns: 55px 1fr 55px; align-items: center; text-align: center; }.publish-sheet header button { background: transparent; color: var(--muted); font-size: 11px; text-align: left; }.publish-sheet header div { display: flex; flex-direction: column; }.publish-sheet header small { color: var(--muted); font-size: 9px; }.publish-sheet header strong { margin-top: 2px; font-size: 14px; }.publish-sheet header > span { color: var(--coral); font-size: 11px; text-align: right; }.publish-progress { height: 3px; margin: 14px -18px 0; background: #f0ece7; }.publish-progress i { display: block; width: 33.33%; height: 100%; background: var(--coral); transition: width .25s; }
.publish-step { display: none; height: 490px; overflow-y: auto; padding: 18px 1px; }.publish-step.active { display: block; animation: fadeUp .25s; }.publish-type { width: 100%; display: flex; align-items: center; gap: 12px; margin-bottom: 9px; padding: 13px; border: 1.5px solid var(--line); border-radius: 17px; background: #fff; text-align: left; }.publish-type > span { display: grid; place-items: center; width: 43px; height: 43px; border-radius: 14px; background: #f7f3ed; font-size: 22px; }.publish-type > div { flex: 1; }.publish-type strong { display: block; font-size: 13px; }.publish-type small { color: var(--muted); font-size: 9px; }.publish-type > .icon { display: none; width: 18px; height: 18px; color: var(--coral); }.publish-type.selected { border-color: var(--coral); background: var(--coral-soft); }.publish-type.selected > .icon { display: inline-flex; }
.form-field { position: relative; display: block; margin-bottom: 15px; }.form-field > span { display: block; margin-bottom: 7px; font-size: 11px; font-weight: 700; }.form-field input, .form-field textarea, .form-field select { width: 100%; border: 1px solid var(--line); border-radius: 14px; outline: 0; background: #f9f7f3; transition: border .2s; }.form-field input, .form-field select { height: 46px; padding: 0 12px; }.form-field textarea { padding: 12px; resize: none; }.form-field input:focus,.form-field textarea:focus { border-color: var(--coral); }.form-field > small { position: absolute; right: 11px; bottom: 15px; color: #aaa; font-size: 8px; }.form-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 9px; }
.photo-field { margin-bottom: 15px; }.photo-field > span { display: block; margin-bottom: 8px; font-size: 11px; font-weight: 700; }.photo-field > span small { color: var(--muted); font-size: 8px; font-weight: 400; }.photo-actions { display: flex; gap: 8px; min-height: 67px; overflow-x: auto; }.photo-actions > label { flex: 0 0 67px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; border: 1px dashed #d8d2ca; border-radius: 13px; color: var(--muted); background: #faf8f5; cursor: pointer; }.photo-actions label b { display: flex; }.photo-actions label .icon { width: 19px; height: 19px; }.photo-actions label em { font-size: 7px; }.photo-previews { display: contents; }.photo-preview { position: relative; flex: 0 0 67px; height: 67px; overflow: hidden; border-radius: 13px; background: #eee; }.photo-preview img { width: 100%; height: 100%; object-fit: cover; }.photo-preview button { position: absolute; right: 3px; top: 3px; width: 18px; height: 18px; display: grid; place-items: center; border-radius: 50%; color: #fff; background: rgba(30,25,22,.65); font-size: 10px; }
.setting-row { display: flex; align-items: center; gap: 11px; padding: 14px 3px; border-bottom: 1px solid var(--line); }.setting-row > div { flex: 1; }.setting-row strong { display: block; font-size: 12px; }.setting-row small { color: var(--muted); font-size: 9px; }.setting-icon { display: grid; place-items: center; width: 39px; height: 39px; border-radius: 13px; color: var(--coral); background: var(--coral-soft); }.setting-icon .icon { width: 17px; height: 17px; }.setting-row input[type=range] { width: 86px; accent-color: var(--coral); }.promise-note { display: flex; gap: 10px; margin-top: 19px; padding: 13px; border-radius: 15px; color: #5f6e68; background: #eaf6f0; }.promise-note .icon { flex: 0 0 auto; color: var(--green); }.promise-note p { margin: 0; font-size: 9px; line-height: 1.55; }.promise-note strong { color: #315f4f; }.publish-sheet footer { padding: 12px 0 max(18px,env(safe-area-inset-bottom)); border-top: 1px solid var(--line); }.primary-button { width: 100%; padding: 14px; border-radius: 15px; color: #fff; background: var(--coral); font-weight: 750; box-shadow: 0 8px 20px rgba(255,91,77,.22); }
.toast { position: fixed; z-index: 80; left: 50%; top: 28px; display: flex; align-items: center; gap: 9px; padding: 11px 16px; border-radius: 14px; color: #fff; background: rgba(36,34,31,.94); box-shadow: 0 10px 30px rgba(20,15,10,.2); transform: translate(-50%,-20px); visibility: hidden; opacity: 0; transition: .25s; }.toast.show { visibility: visible; opacity: 1; transform: translate(-50%,0); }.toast .icon { width: 16px; height: 16px; color: #74dfa8; }.toast p { margin: 0; font-size: 11px; }
.auth-gate { position: fixed; z-index: 100; inset: 0; display: grid; place-items: center; padding: 20px; visibility: hidden; opacity: 0; background: rgba(242,238,232,.94); backdrop-filter: blur(18px); transition: .25s; }.auth-gate.open { visibility: visible; opacity: 1; }.auth-card { width: min(390px,100%); padding: 30px 25px 22px; border: 1px solid rgba(255,255,255,.8); border-radius: 29px; background: var(--paper); box-shadow: 0 25px 70px rgba(50,40,32,.15); }.auth-logo { display: flex; margin-bottom: 25px; }.auth-card h2 { margin: 7px 0 7px; font-size: 27px; letter-spacing: -.045em; }.auth-subtitle { margin: 0 0 25px; color: var(--muted); font-size: 11px; }.auth-step { display: none; }.auth-step.active { display: block; animation: fadeUp .25s; }.auth-step label > span { display: block; margin-bottom: 8px; font-size: 11px; font-weight: 700; }.auth-input { height: 50px; display: flex; align-items: center; margin-bottom: 14px; border: 1px solid var(--line); border-radius: 14px; background: #f8f5f1; }.auth-input em { padding: 0 12px; border-right: 1px solid var(--line); font-size: 12px; }.auth-input input,.code-input { min-width: 0; flex: 1; height: 100%; padding: 0 12px; border: 0; outline: 0; background: transparent; }.code-input { width: 100%; height: 54px; margin-bottom: 14px; border: 1px solid var(--line); border-radius: 14px; background: #f8f5f1; font-size: 24px; font-weight: 700; letter-spacing: .25em; text-align: center; }.auth-back { display: flex; align-items: center; gap: 8px; margin-bottom: 18px; color: var(--muted); font-size: 10px; }.auth-back button { display: grid; place-items: center; width: 30px; height: 30px; border-radius: 10px; background: #f2efeb; }.auth-back .icon { width: 15px; height: 15px; }.resend-button,.demo-entry { width: 100%; margin-top: 11px; padding: 8px; background: transparent; color: var(--coral); font-size: 10px; }.resend-button:disabled { color: #aaa; }.demo-entry { margin-top: 17px; padding-top: 16px; border-top: 1px solid var(--line); color: #777; }.auth-consent { margin: 10px 0 0; color: #aaa; font-size: 8px; text-align: center; }

.feature-sheet { height: min(790px,calc(100vh - 30px)); overflow: hidden; padding-bottom: 0; }
.feature-header { display: grid; grid-template-columns: 45px 1fr 45px; align-items: center; padding-bottom: 13px; border-bottom: 1px solid var(--line); text-align: center; }
.feature-header button { display: grid; place-items: center; width: 35px; height: 35px; border-radius: 12px; background: #f2efeb; }
.feature-header .icon { width: 17px; height: 17px; }.feature-header div { display: flex; flex-direction: column; }.feature-header small { color: var(--muted); font-size: 8px; }.feature-header strong { margin-top: 2px; font-size: 14px; }
#featureContent { height: calc(100% - 68px); overflow-y: auto; padding: 16px 1px 28px; scrollbar-width: none; }
.sub-hero { position: relative; overflow: hidden; padding: 20px; border-radius: 21px; color: #fff; background: linear-gradient(135deg,#303b39,#1f2927); }.sub-hero.coral-bg { background: linear-gradient(135deg,#ff735f,#ed4b41); }.sub-hero.blue-bg { background: linear-gradient(135deg,#668ee8,#426bcc); }.sub-hero h2 { margin: 7px 0; font-size: 22px; letter-spacing: -.04em; }.sub-hero p { max-width: 270px; margin: 0; color: rgba(255,255,255,.7); font-size: 10px; line-height: 1.6; }.sub-hero > span { font-size: 9px; opacity: .65; }.sub-hero .hero-number { position: absolute; right: 18px; top: 21px; font-size: 43px; font-weight: 800; opacity: .15; }
.sub-tabs { display: flex; gap: 7px; margin: 15px 0 11px; }.sub-tabs button { padding: 7px 11px; border-radius: 10px; color: var(--muted); background: #f2efeb; font-size: 10px; }.sub-tabs button.active { color: #fff; background: var(--ink); }
.mini-broadcast { margin-bottom: 10px; padding: 14px; border: 1px solid var(--line); border-radius: 17px; background: #fff; }.mini-broadcast header { display: flex; align-items: center; justify-content: space-between; }.status-tag { padding: 5px 8px; border-radius: 8px; color: var(--green); background: #eaf7f1; font-size: 8px; font-weight: 700; }.status-tag.done { color: #827b73; background: #f1efec; }.mini-broadcast time { color: var(--muted); font-size: 8px; }.mini-broadcast h3 { margin: 11px 0 6px; font-size: 13px; }.mini-broadcast p { margin: 0 0 11px; color: var(--muted); font-size: 9px; }.mini-broadcast footer { display: flex; align-items: center; gap: 8px; }.mini-broadcast footer .progress-track { flex: 1; margin: 0; }.mini-broadcast footer strong { color: var(--coral); font-size: 9px; }
.trust-score { display: grid; grid-template-columns: 110px 1fr; gap: 15px; align-items: center; padding: 18px; border-radius: 21px; background: #eff8f3; }.score-ring { width: 102px; height: 102px; display: grid; place-items: center; border: 9px solid #d4eee2; border-top-color: var(--green); border-right-color: var(--green); border-radius: 50%; transform: rotate(45deg); }.score-ring div { transform: rotate(-45deg); text-align: center; }.score-ring strong { display: block; color: #247c60; font-size: 25px; }.score-ring small { color: #6f9486; font-size: 8px; }.trust-score h3 { margin: 0 0 5px; font-size: 14px; }.trust-score p { margin: 0; color: #698078; font-size: 9px; line-height: 1.6; }
.record-list { margin-top: 14px; }.record-list h3,.setting-section h3 { margin: 0 0 9px; font-size: 13px; }.record-row { display: flex; align-items: center; gap: 10px; padding: 12px 2px; border-bottom: 1px solid var(--line); }.record-row > span { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 12px; background: #f4f1ed; }.record-row div { flex: 1; }.record-row strong { display: block; font-size: 10px; }.record-row small { color: var(--muted); font-size: 8px; }.record-row em { color: var(--green); font-size: 9px; }
.invite-code { margin-top: 14px; padding: 17px; border: 1px dashed #d6d0c8; border-radius: 18px; text-align: center; }.invite-code small { color: var(--muted); font-size: 9px; }.invite-code strong { display: block; margin: 8px 0; font-size: 27px; letter-spacing: .16em; }.invite-code button,.feature-primary { width: 100%; padding: 13px; border-radius: 14px; color: #fff; background: var(--coral); font-size: 11px; font-weight: 700; }.invite-code button { margin-top: 8px; }.invite-steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-top: 15px; }.invite-steps div { padding: 12px 8px; border-radius: 14px; background: #f5f2ed; text-align: center; }.invite-steps b { display: grid; place-items: center; width: 25px; height: 25px; margin: auto; border-radius: 50%; color: #fff; background: var(--coral); font-size: 10px; }.invite-steps strong { display: block; margin-top: 7px; font-size: 9px; }.invite-steps small { color: var(--muted); font-size: 7px; }
.merchant-benefits { display: grid; grid-template-columns: repeat(2,1fr); gap: 9px; margin: 14px 0; }.merchant-benefits div { padding: 14px; border-radius: 16px; background: #f6f3ee; }.merchant-benefits span { font-size: 22px; }.merchant-benefits strong { display: block; margin-top: 8px; font-size: 10px; }.merchant-benefits small { color: var(--muted); font-size: 8px; }
.setting-section { margin-bottom: 18px; }.setting-button { width: 100%; display: flex; align-items: center; gap: 10px; padding: 12px 2px; border-bottom: 1px solid var(--line); background: transparent; text-align: left; }.setting-button > .icon:first-child { color: var(--muted); }.setting-button div { flex: 1; }.setting-button strong { display: block; font-size: 10px; }.setting-button small { color: var(--muted); font-size: 8px; }.toggle { width: 39px; height: 23px; padding: 3px; border-radius: 20px; background: #d9d5d0; }.toggle i { display: block; width: 17px; height: 17px; border-radius: 50%; background: #fff; transition: .2s; }.toggle.on { background: var(--green); }.toggle.on i { transform: translateX(16px); }
.chat-owner { display: flex; align-items: center; gap: 10px; padding: 12px; border-radius: 16px; background: #f6f3ee; }.chat-owner div { flex: 1; }.chat-owner strong { display: block; font-size: 11px; }.chat-owner small { color: var(--muted); font-size: 8px; }.chat-owner button { padding: 6px 9px; border-radius: 8px; color: var(--coral); background: var(--coral-soft); font-size: 8px; }.chat-day { margin: 17px 0; color: #aaa; font-size: 8px; text-align: center; }.bubble-row { display: flex; align-items: end; gap: 7px; margin: 11px 0; }.bubble-row.me { justify-content: flex-end; }.bubble { max-width: 74%; padding: 10px 12px; border-radius: 14px 14px 14px 4px; background: #f1eee9; font-size: 10px; line-height: 1.55; }.bubble-row.me .bubble { border-radius: 14px 14px 4px 14px; color: #fff; background: var(--coral); }.chat-compose { position: sticky; bottom: -28px; display: flex; gap: 8px; margin: 25px -1px 0; padding: 12px 0 4px; background: var(--paper); }.chat-compose input { min-width: 0; flex: 1; height: 42px; padding: 0 12px; border: 1px solid var(--line); border-radius: 13px; outline: 0; background: #f7f4ef; }.chat-compose button { padding: 0 15px; border-radius: 12px; color: #fff; background: var(--coral); font-size: 10px; }
.voice-panel { text-align: center; }.voice-orb { position: relative; width: 112px; height: 112px; display: grid; place-items: center; margin: 25px auto 20px; border-radius: 50%; color: #fff; background: linear-gradient(145deg,#ff7765,#ee493f); box-shadow: 0 15px 34px rgba(238,73,63,.28); }.voice-orb::before,.voice-orb::after { content:""; position:absolute; inset:-11px; border:1px solid rgba(255,91,77,.25); border-radius:50%; animation:voiceWave 2s infinite; }.voice-orb::after { inset:-24px; animation-delay:.5s; }.voice-orb .icon { width: 34px; height: 34px; }@keyframes voiceWave{50%{transform:scale(1.07);opacity:.35}}.voice-panel h3 { margin: 0; font-size: 18px; }.voice-panel > p { margin: 7px auto 20px; color: var(--muted); font-size: 10px; }.voice-examples { display: grid; gap: 8px; text-align: left; }.voice-examples button { display: flex; align-items: center; gap: 10px; padding: 12px; border-radius: 14px; background: #f5f2ed; }.voice-examples span { font-size: 18px; }.voice-examples strong { display: block; font-size: 10px; }.voice-examples small { display: block; margin-top: 2px; color: var(--muted); font-size: 8px; }.voice-privacy { margin-top: 16px!important; padding: 10px; border-radius: 12px; color: #557267!important; background: #eef7f3; line-height: 1.5; }

@media (max-width: 900px) {
  body { background: var(--paper); }
  .ambient, .brand-panel { display: none; }
  .app-shell { display: block; min-height: 100vh; padding: 0; }
  .phone-stage { width: 100%; height: 100vh; min-height: 600px; padding: 0; border: 0; border-radius: 0; background: none; box-shadow: none; }
  .phone-app { border-radius: 0; }
}
@media (max-width: 360px) { .page { padding-left: 12px; padding-right: 12px; }.hero-card { padding: 18px; }.radar-visual { right: -18px; }.quick-icon { width: 44px; height: 44px; }.broadcast-card { padding: 13px; } }
@media (prefers-reduced-motion: reduce) { *,*::before,*::after { animation-duration: .01ms!important; transition-duration: .01ms!important; } }
