:root{--bg: #ffffff;--bg-soft: #f3f4f6;--bg-elevated: #ffffff;--accent: #22c55e;--accent-soft: rgba(34, 197, 94, .12);--accent-strong: #16a34a;--danger: #ef4444;--text: #0f172a;--text-soft: #6b7280;--border-subtle: rgba(148, 163, 184, .6);--radius-lg: 18px;--transition-fast: .18s ease-out}*,*:before,*:after{box-sizing:border-box}html{height:100%}html,body{margin:0;padding:0;font-family:-apple-system,system-ui,BlinkMacSystemFont,Helvetica Neue,Arial,"Apple Color Emoji","Segoe UI Emoji",sans-serif;background:#dcfce7;color:var(--text);font-size:15px;line-height:1.4}body{height:100%;max-height:100vh;max-height:100dvh;overflow:hidden}#root{height:100%;max-height:100vh;max-height:100dvh;overflow:hidden;display:flex;justify-content:center;align-items:stretch}.app-shell{width:100%;max-width:430px;flex:1;min-height:0;height:100%;max-height:100vh;max-height:100dvh;overflow:hidden;background:#fff;color:var(--text);padding:max(2px,calc(env(safe-area-inset-top,0px) - 4px)) 12px 20px;display:flex;flex-direction:column;gap:12px}.smart-banner{flex-shrink:0;position:sticky;top:env(safe-area-inset-top,0px);z-index:55;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border-radius:14px;background:#ffffffeb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 10px 25px #0f172a1f;border:1px solid rgba(209,213,219,.9)}.smart-banner-left{display:flex;align-items:center;gap:10px;min-width:0}.smart-banner-icon{width:34px;height:34px;border-radius:10px;flex-shrink:0;box-shadow:0 4px 14px #10b98140}.smart-banner-text{display:flex;flex-direction:column;gap:2px;min-width:0}.smart-banner-title{font-size:13px;font-weight:900;color:#111827;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.smart-banner-sub{font-size:11px;color:#6b7280;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.smart-banner-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.smart-banner-btn{text-decoration:none;border:none;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:800;cursor:pointer;min-height:34px;display:inline-flex;align-items:center;justify-content:center}.smart-banner-btn-open{background:#16a34a1f;color:#166534;box-shadow:0 0 0 1px #16a34a40}.smart-banner-btn-install{background:linear-gradient(135deg,var(--accent-strong),#4ade80);color:#022c22;box-shadow:0 12px 24px #10b98159}.app-header{flex-shrink:0;display:flex;flex-direction:column;gap:2px;padding:4px 10px 9px;border-radius:0 0 10px 10px;background:#dcfce7}.app-header-row{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;flex-wrap:nowrap}.app-title{display:flex;align-items:center;gap:8px;min-width:0;flex:1 1 auto;overflow:hidden}.app-title-main{font-family:-apple-system,system-ui,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;font-size:26px;font-weight:900;letter-spacing:.03em;color:#16a34a;line-height:1.2;flex:0 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-header-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex:0 0 auto;flex-shrink:0}.app-title-sub{font-family:-apple-system,system-ui,BlinkMacSystemFont,Helvetica Neue,Arial,sans-serif;font-size:12px;font-weight:600;color:var(--text-soft);line-height:1.2;letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:3px}.pill{border-radius:999px;border:1px solid var(--border-subtle);padding:4px 10px;font-size:11px;color:var(--text-soft);display:inline-flex;align-items:center;gap:4px}.lang-toggle{border-radius:999px;border:1px solid var(--border-subtle);padding:2px;display:inline-flex;background:#0f172acc}.lang-toggle button{border:none;background:transparent;color:var(--text-soft);padding:7px 12px;border-radius:999px;font-size:12px;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.lang-toggle button.active{background:var(--accent-soft);color:var(--accent)}.btn{border-radius:999px;border:none;padding:10px 16px;font-size:14px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#0f172ad9;color:var(--text);box-shadow:0 0 0 1px #94a3b859;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.btn:active{transform:scale(.97)}.btn-primary{background:linear-gradient(135deg,var(--accent-strong),#4ade80);color:#022c22;box-shadow:0 16px 35px #10b98180}.btn-ghost{background:transparent;box-shadow:0 0 0 1px #94a3b866}.btn-icon-only{width:42px;height:42px;border-radius:999px;padding:0}.screen{flex:1;min-height:0;border-radius:26px;padding:12px 12px 6px;background:#f3f4f6;box-shadow:0 18px 50px #0f172a1f;display:flex;flex-direction:column;gap:12px;overflow:hidden}.tabs{display:inline-flex;padding:3px;border-radius:999px;background:#e5e7eb;box-shadow:0 0 0 1px #94a3b859;gap:2px;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs button{border-radius:999px;border:none;padding:10px 14px;background:transparent;color:var(--text-soft);font-size:13px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;white-space:nowrap;transition:background var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.tabs button.active{background:var(--accent-soft);color:var(--accent)}.group-detail-tabs{width:100%;padding:1px;gap:1px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));overflow:hidden;border-radius:12px}.group-detail-tabs button{min-width:0;padding:5px 9px;justify-content:center;border-radius:10px}.screen-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.segmented{display:inline-flex;padding:3px;border-radius:999px;background:#e5e7eb;box-shadow:0 0 0 1px #94a3b866}.segmented button{border-radius:999px;border:none;padding:10px 14px;background:transparent;color:var(--text-soft);font-size:13px;cursor:pointer}.segmented button.active{background:var(--accent-soft);color:var(--accent)}.payments-view-segmented{width:100%;padding:1px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-radius:12px;overflow:hidden}.payments-view-segmented button{min-width:0;padding:5px 9px;justify-content:center;border-radius:10px}.scroll-area{flex:1;min-height:0;overflow-y:auto;padding-right:2px;padding-bottom:8px;overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}.pull-refresh-floating{position:absolute;top:6px;left:50%;transform:translate(-50%);z-index:70;min-width:112px;min-height:34px;padding:8px 14px;border-radius:999px;background:#111827;color:#f9fafb;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;box-shadow:0 14px 35px #0f172a47;pointer-events:none}.scroll-area.scroll-area--payments-split{display:flex;flex-direction:column;overflow:hidden}.payments-tab-sticky{flex-shrink:0}.payments-view-row{margin-top:8px;display:flex;width:100%}.payments-tab-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain;padding-right:2px;padding-bottom:max(8px,env(safe-area-inset-bottom,0px))}.payments-tab-scroll::-webkit-scrollbar{width:4px}.payments-tab-scroll::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:999px}.receipt-trace-scroll{isolation:isolate;overscroll-behavior:contain}.group-detail-root{min-height:0}.scroll-area::-webkit-scrollbar{width:4px}.scroll-area::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:999px}.group-card{border-radius:var(--radius-lg);background:#fff;width:100%;padding:26px 11px;display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;text-align:left;box-shadow:0 12px 28px #0f172a14;border:1px solid rgba(209,213,219,.9);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.group-card:hover{transform:translateY(-1px);box-shadow:0 16px 45px #0f172a1f;border-color:#94a3b8}.group-main{display:flex;align-items:center;gap:10px;width:100%;min-width:0}.group-icon{width:44px;height:44px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 20% 0,#e5e7eb,#d1d5db 60%);font-size:24px;box-shadow:inset 0 0 0 1px #94a3b866}.group-meta{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.group-title-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px;min-width:0}.group-title{min-width:0;font-size:20px;font-weight:700;letter-spacing:.02em;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-count{flex:0 0 auto;color:#9ca3af;font-size:11px;font-weight:600;text-align:right;white-space:nowrap}.group-sub{font-size:11px;color:var(--text-soft)}.group-header-name{color:inherit}.group-header{background:#fef9c3;border-radius:18px;padding:6px 10px}.group-detail-heading{display:flex;flex-direction:column;gap:1px;padding:0 0 2px}.group-detail-back{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;border:none;background:transparent;color:#6b7280;font-size:15px;font-weight:500;line-height:1.1;padding:0;cursor:pointer}.group-detail-back-arrow{font-size:28px;font-weight:400;line-height:1;transform:translateY(-1px)}.group-detail-title-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:6px;min-width:0;padding:7px 8px;border-radius:18px;background:#fef9c3}.group-detail-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:16px;line-height:1;flex-shrink:0}.group-detail-title{min-width:0;color:#374151;font-size:16px;font-weight:700;line-height:1.08;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-detail-actions{display:flex;align-items:center;gap:4px;overflow:visible}.group-detail-invite-wrap{position:relative;display:inline-flex;align-items:center;overflow:visible;justify-content:center}.group-detail-invite-bubble{position:absolute;top:calc(100% + 3px);right:0;left:auto;transform:none;width:max-content;max-width:min(180px,calc(100vw - 18px));padding:8px 10px;border-radius:15px;border:1px solid rgba(148,163,184,.72);background:#fffffffa;color:#9ca3af;font-size:13px;font-weight:800;line-height:1.08;box-shadow:0 10px 18px #0f172a2e;z-index:2}.group-detail-invite-bubble:before{content:"";position:absolute;right:13px;top:-16px;width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:18px solid rgba(148,163,184,.72);filter:drop-shadow(0 -1px 0 rgba(148,163,184,.18))}.group-detail-invite-bubble:after{content:"";position:absolute;right:14px;top:-15px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:17px solid rgba(255,255,255,.98);filter:drop-shadow(0 -1px 2px rgba(15,23,42,.12))}.guide-bubble-close{position:absolute;top:6px;right:6px;width:18px;height:18px;border:none;border-radius:999px;background:#16653414;color:#166534;font-size:14px;line-height:1;font-weight:700;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.guide-bubble-close span{position:relative;top:-1px}.guide-bubble-text{padding-right:0}.invite-guide-bubble-text{white-space:pre-line}.guide-bubble-body{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;min-height:78px;text-align:center;padding-top:6px}.guide-bubble-icon{width:54px;height:54px;flex:0 0 auto;object-fit:contain;background:transparent;margin:0;filter:drop-shadow(0 7px 11px rgba(15,23,42,.12))}.invite-guide-bubble-text{color:#9ca3af;font-size:13px;line-height:1.06;text-align:center}.payments-add-wrap{position:relative;display:inline-flex;flex-direction:column;align-items:flex-end;overflow:visible}.payments-add-bubble{position:absolute;top:calc(100% + 6px);right:0;width:max-content;max-width:min(170px,calc(100vw - 16px));padding:8px 8px 10px;border-radius:16px;border:1px solid rgba(148,163,184,.72);background:#fffffffa;color:#9ca3af;font-size:13px;font-weight:800;line-height:1.08;box-shadow:0 10px 18px #0f172a2e;z-index:2}.payments-add-bubble:after{content:"";position:absolute;right:16px;top:-15px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:17px solid rgba(255,255,255,.98);filter:drop-shadow(0 -2px 4px rgba(15,23,42,.12))}.payments-add-bubble:before{content:"";position:absolute;right:15px;top:-17px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:18px solid rgba(148,163,184,.72);filter:drop-shadow(0 -1px 1px rgba(148,163,184,.16))}.payments-add-bubble-body{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;min-height:76px;padding:1px 2px 0;text-align:center}.payments-add-bubble-icon{width:54px;height:54px;background:transparent;flex:0 0 auto;margin:0;filter:drop-shadow(0 7px 11px rgba(15,23,42,.12));object-fit:contain}.payments-add-bubble-text{flex:1;color:#9ca3af;font-size:13px;line-height:1.06;white-space:pre-line;text-align:center}.settlement-guide-wrap{margin:10px 0 2px;display:flex;justify-content:center}.settlement-guide-wrap--end{margin:12px 0 6px}.settlement-guide-wrap--start{margin:10px 0 2px;justify-content:flex-start;padding-left:0}.settlement-guide-card{position:relative;display:flex;align-items:center;gap:12px;width:fit-content;max-width:min(320px,calc(100vw - 24px));padding:10px 14px 10px 12px;border-radius:999px;border:1px solid rgba(148,163,184,.72);background:#fffffffa;box-shadow:0 8px 14px #0f172a29}.settlement-guide-card--end{flex-direction:column;align-items:center;gap:8px;max-width:min(404px,calc(100vw - 18px));background:linear-gradient(180deg,#ecfdf5fa,#fffffffc);border-color:#22c55e38;box-shadow:0 12px 22px #0f172a2e;padding:15px 18px 16px;min-height:220px}.settlement-guide-card--start{flex-direction:row;align-items:center;gap:12px;max-width:min(332px,calc(100vw - 18px));background:#fffffffc;border-color:#94a3b8b8;box-shadow:0 7px 14px #0f172a29;padding:13px 16px 13px 13px;min-height:0;border-radius:26px}.settlement-guide-card--start:before{left:22px;transform:none;top:-12px;border-left-width:8px;border-right-width:8px;border-bottom-width:14px;border-bottom-color:#94a3b8b8;filter:drop-shadow(0 -1px 1px rgba(15,23,42,.08))}.settlement-guide-card--start:after{left:23px;transform:none;top:-11px;border-left-width:7px;border-right-width:7px;border-bottom-width:13px;border-bottom-color:#fffffffc;filter:drop-shadow(0 -1px 1px rgba(15,23,42,.06))}.settlement-guide-card:before{content:"";position:absolute;left:50%;top:-13px;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:15px solid rgba(34,197,94,.22);filter:drop-shadow(0 -1px 1px rgba(148,163,184,.14))}.settlement-guide-card:after{content:"";position:absolute;left:50%;top:-12px;transform:translate(-50%);width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:14px solid rgba(248,253,249,.99);filter:drop-shadow(0 -1px 2px rgba(15,23,42,.1))}.settlement-guide-close{top:7px;right:7px;z-index:2}.settlement-guide-icon{width:46px;height:46px;flex:0 0 auto;object-fit:contain;background:transparent;margin:0;filter:drop-shadow(0 5px 8px rgba(15,23,42,.1));position:relative;z-index:1}.settlement-guide-text{color:#9ca3af;font-size:13px;line-height:1.08;white-space:pre-line;font-weight:700;text-align:left;position:relative;z-index:1}.settlement-guide-text--end{font-size:12px;line-height:1.42;text-align:center;max-width:362px;font-weight:650}.settlement-guide-text--start{font-size:13px;line-height:1.18;text-align:left;white-space:pre-line;max-width:188px;font-weight:800;color:#9ca3af}.settlement-guide-text-title{font-size:14px;line-height:1.2;font-weight:800;color:#374151;margin-bottom:4px}.settlement-guide-text-body{font-size:12px;line-height:1.42;font-weight:650;color:#6b7280;white-space:pre-line;text-align:center;max-width:330px}.receipt-pending-notice{margin:10px 0 12px;display:flex;flex-direction:column;align-items:center;gap:8px}.receipt-pending-title{font-size:15px;font-weight:800;color:#166534;letter-spacing:0;text-align:center}.receipt-pending-bubble{position:relative;max-width:min(420px,calc(100vw - 20px));padding:12px 14px;border-radius:18px;border:1px solid rgba(134,239,172,.55);background:linear-gradient(180deg,#f0fdf4fa,#fffffffc);box-shadow:0 10px 18px #0f172a1f}.receipt-pending-bubble:before{content:"";position:absolute;left:50%;top:-12px;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:13px solid rgba(134,239,172,.55)}.receipt-pending-bubble:after{content:"";position:absolute;left:50%;top:-11px;transform:translate(-50%);width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:12px solid rgba(255,255,255,.99)}.receipt-pending-bubble-text{font-size:13px;line-height:1.45;color:#374151;font-weight:700;text-align:center;white-space:pre-line}.receipt-pdf-guide{position:relative;align-self:flex-end;width:fit-content;max-width:min(240px,calc(100vw - 28px));padding:10px 12px 11px;border-radius:18px;border:1px solid rgba(134,239,172,.55);background:linear-gradient(180deg,#f0fdf4fa,#fffffffc);box-shadow:0 10px 18px #0f172a1f;margin-top:2px}.receipt-pdf-guide:before{content:"";position:absolute;right:34px;top:-12px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:13px solid rgba(134,239,172,.55)}.receipt-pdf-guide:after{content:"";position:absolute;right:35px;top:-11px;width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-bottom:12px solid rgba(255,255,255,.99)}.receipt-pdf-guide-text{font-size:13px;line-height:1.4;color:#374151;font-weight:700;text-align:center;white-space:pre-line}.receipt-pdf-guide-close{top:6px;right:6px}.group-detail-action-btn{min-width:34px;height:34px;border:1px solid rgba(134,239,172,.62);border-radius:10px;background:#fff9;color:#4b5563;font-size:17px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;padding:0 8px;cursor:pointer}.group-detail-action-invite{color:#166534;font-size:12px;border:1px solid rgba(134,239,172,.8);background:#f0fdf4e6}.badge{border-radius:999px;padding:4px 8px;font-size:10px;display:inline-flex;align-items:center;gap:4px}.badge-green{background:#22c55e1f;color:#6ee7b7}.badge-amber{background:#f59e0b29;color:#facc15}.badge-soft{background:#0f172acc;color:var(--text-soft)}.chip-row{display:flex;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px;margin-top:4px;padding-bottom:2px}.fab{position:fixed;right:22px;bottom:calc(env(safe-area-inset-bottom,0px) + 90px);width:60px;height:60px;border-radius:999px;background:radial-gradient(circle at 20% 0,#4ade80,#22c55e 55%,#22c55e);color:#022c22;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 20px 45px #10b98166;border:none;cursor:pointer;transform-origin:center;transition:transform .14s ease-out,box-shadow .14s ease-out}.fab-inline{width:52px;height:52px;border-radius:999px;background:radial-gradient(circle at 20% 0,#4ade80,#22c55e 55%,#22c55e);color:#022c22;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;border:none;cursor:pointer;flex-shrink:0;box-shadow:0 4px 12px #10b98159}.fab:active{transform:scale(.94) translateY(1px);box-shadow:0 14px 35px #10b981b3}.create-event-callout{position:fixed;right:92px;bottom:calc(env(safe-area-inset-bottom,0px) + 100px);z-index:39;min-width:210px;max-width:min(260px,calc(100vw - 128px));min-height:72px;padding:10px 16px 10px 12px;border-radius:15px;border:2px solid rgba(148,163,184,.72);background:#fffffff5;box-shadow:0 10px 18px #0f172a2e;display:flex;align-items:center;gap:6px;pointer-events:none}.create-event-callout:after{content:"";position:absolute;right:-13px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:14px solid transparent;border-bottom:14px solid transparent;border-left:20px solid rgba(255,255,255,.96);filter:drop-shadow(2px -1px 2px rgba(15,23,42,.12))}.create-event-callout:before{content:"";position:absolute;right:-14px;top:50%;transform:translateY(-50%);width:0;height:0;border-top:15px solid transparent;border-bottom:15px solid transparent;border-left:21px solid rgba(148,163,184,.72);filter:drop-shadow(0 0 0 rgba(148,163,184,.18))}.create-event-callout-icon{width:64px;height:64px;object-fit:contain;flex:0 0 auto;margin:0;filter:drop-shadow(0 10px 14px rgba(15,23,42,.12));background:transparent}.create-event-callout-text{color:#374151;font-size:14px;font-weight:800;line-height:1.45;white-space:pre-line}.guide-button-wrap{position:fixed;bottom:20px;left:50%;z-index:40;transform:translate(-50%)}.guide-button-pill{min-height:34px;padding:5px 13px;border-radius:999px;border:1.5px solid #86efac;background:#ffffffeb;color:#14532d;font-size:13px;font-weight:800;box-shadow:0 7px 18px #16a34a1f;cursor:pointer}.guide-button-pill:active{transform:translateY(1px)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172aa6;display:flex;justify-content:center;align-items:flex-end;z-index:80;overscroll-behavior:none}.modal-overlay .modal{touch-action:pan-y;overscroll-behavior:contain}body.receipt-scan-modal-open .scroll-area--payments-split,body.receipt-scan-modal-open .payments-tab-scroll{overflow:hidden!important;overscroll-behavior:none;touch-action:none}.modal,.modal-card{width:100%;max-width:430px;background:#fff;border-radius:26px 26px 0 0;padding:14px 16px 20px;box-shadow:0 -16px 45px #0f172a1f;border-top:1px solid rgba(209,213,219,.9);color:var(--text);max-height:min(85dvh,720px);overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain}.payment-modal{overscroll-behavior-x:none}.fx-rate-failure-modal{align-self:center;width:calc(100% - 32px);max-width:420px;border-radius:26px;border:1px solid rgba(209,213,219,.95);box-shadow:0 22px 60px #0f172a38;margin:16px}.currency-search-dropdown-portal{background:linear-gradient(180deg,#ecfdf5,#d1fae5);border:2px solid #34d399;border-radius:12px;box-shadow:0 10px 28px #10b98147}.currency-search-dropdown-anchor{position:absolute;left:0;right:0;bottom:calc(100% + 6px);z-index:100;display:flex;flex-direction:column;max-height:min(360px,58vh);max-height:min(360px,58dvh);overflow:hidden;box-sizing:border-box;min-height:0}.currency-search-dropdown-anchor--below{bottom:auto!important;top:calc(100% + 6px)}.currency-search-dropdown-inner-search{flex-shrink:0;padding:8px 10px;border-bottom:1px solid rgba(52,211,153,.45);background:linear-gradient(180deg,#ecfdf5,#d1fae5)}.currency-search-dropdown-inner-search input{width:100%;box-sizing:border-box;padding:10px 12px;border-radius:10px;border:1px solid #6ee7b7;font-size:14px;background:#fff}.currency-search-dropdown-scroll{flex:0 0 auto;height:min(260px,42dvh);min-height:120px;max-height:min(280px,48dvh);overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y;overscroll-behavior:contain}.currency-search-dropdown-portal [role=option]:last-child,.currency-search-dropdown-scroll [role=option]:last-child{border-bottom:none!important}.review-prompt-modal{align-self:center;max-width:460px;border-radius:26px;box-shadow:0 22px 80px #0f172a59;border:1px solid rgba(34,197,94,.25);background:radial-gradient(120% 120% at 50% 0%,#22c55e1a,#fff 55%)}.review-prompt-hero{text-align:center;font-size:28px;letter-spacing:.12em;color:#f59e0b;margin-top:6px;margin-bottom:8px;font-weight:900}.review-prompt-body{white-space:pre-line;text-align:center;font-size:16px;font-weight:800;color:#111827;line-height:1.65;margin:0 4px 14px}.review-prompt-modal .modal-title{font-size:18px;font-weight:900}.review-prompt-modal .btn{min-height:50px;font-size:16px}.update-prompt-modal{align-self:center;max-width:420px;border-radius:20px;padding:18px 18px 20px;box-shadow:0 24px 90px #0f172a59;border:1px solid rgba(209,213,219,.9)}.update-prompt-hero{display:flex;justify-content:center;margin:6px 0 14px}.update-illust{position:relative;width:270px;height:170px}.update-illust-bg{position:absolute;top:18px;right:12px;bottom:26px;left:12px;border-radius:28px;background:#22c55e1f}.update-illust-phone{position:absolute;left:50%;top:18px;transform:translate(-50%);width:104px;height:152px;border-radius:22px;background:linear-gradient(180deg,#34d399,#16a34a);box-shadow:0 22px 55px #0f172a38;border:6px solid #0f172a}.update-illust-phone-notch{position:absolute;top:6px;left:50%;transform:translate(-50%);width:52px;height:10px;border-radius:999px;background:#0f172a8c}.update-illust-phone-icon{position:absolute;top:42px;left:50%;transform:translate(-50%);color:#eafff4;font-size:34px;font-weight:900;text-shadow:0 6px 14px rgba(0,0,0,.18)}.update-illust-phone-bar{position:absolute;top:92px;left:50%;transform:translate(-50%);width:72px;height:10px;border-radius:999px;background:#ffffff59;overflow:hidden}.update-illust-phone-bar-fill{width:42%;height:100%;border-radius:999px;background:#fffffff2}.update-illust-phone-label{position:absolute;top:112px;left:50%;transform:translate(-50%);font-size:10px;letter-spacing:.1em;font-weight:800;color:#eafff4f2}.update-illust-badge{position:absolute;top:56px;width:46px;height:46px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:18px;color:#166534;background:#22c55e33;box-shadow:0 10px 25px #10b9812e}.update-illust-badge-left{left:10px}.update-illust-badge-right{right:10px}.update-illust-leaf{position:absolute;bottom:14px;width:64px;height:28px;background:#16a34a59;border-radius:999px 999px 999px 0;filter:blur(.1px)}.update-illust-leaf-left{left:52px;transform:rotate(-12deg)}.update-illust-leaf-right{right:52px;transform:rotate(12deg) scaleX(-1)}.update-prompt-title{text-align:center;font-size:22px;font-weight:900;letter-spacing:.02em;color:#111827;margin:2px 4px 8px}.update-prompt-body{white-space:pre-line;text-align:center;font-size:14px;font-weight:600;color:#374151;line-height:1.7;margin:0 4px 14px}.update-prompt-footnote{display:flex;gap:6px;align-items:flex-start;justify-content:center;text-align:center;font-size:11px;color:#6b7280;line-height:1.5;margin:-6px 6px 14px}.update-prompt-modal .modal-title{font-size:14px;font-weight:800;color:#111827}.update-prompt-modal .btn{min-height:48px;font-size:16px;font-weight:800}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.modal-title{font-size:16px;font-weight:600}.modal-close{border-radius:999px;border:none;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:#0f172ae6;color:var(--text-soft);cursor:pointer}.form-grid{display:grid;grid-template-columns:1fr;gap:10px;max-height:60vh;overflow-y:auto}.form-grid--with-dropdown,.form-grid--payment-modal{overflow:visible;max-height:none}.field-label{font-size:12px;color:var(--text-soft);margin-bottom:4px}.field-control{border-radius:14px;background:#fff;border:1px solid rgba(209,213,219,1);min-height:44px;padding:12px;color:var(--text);font-size:16px;width:100%}.payment-modal .field-control{min-width:0}.currency-field-spacer{visibility:hidden;margin-bottom:4px;pointer-events:none}.currency-search-trigger{width:100%;height:44px;min-height:44px;padding-block:0;display:flex;align-items:center;justify-content:space-between;gap:10px;text-align:left;cursor:pointer}.currency-search-trigger-main{min-width:0;display:flex;align-items:center;gap:4px;flex-wrap:wrap}.currency-search-trigger-code{font-size:16px;font-weight:800;color:var(--text)}.currency-search-trigger-hint{font-size:10px;color:#94a3b8;font-weight:600;white-space:nowrap}.currency-search-trigger-icon{flex-shrink:0;width:30px;height:30px;border-radius:999px;border:1px solid #94a3b8;background:#eef2ff;color:#334155;box-shadow:0 1px #ffffffe6 inset,0 1px 2px #0f172a14;display:grid;place-items:center;font-size:13px;line-height:1}.field-control--date{width:100%;padding-right:40px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.field-control--date::-webkit-calendar-picker-indicator{opacity:0;margin:0}.field-control--date::-webkit-inner-spin-button,.field-control--date::-webkit-clear-button{display:none}.date-field-shell{position:relative}.date-field-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:999px;border:1px solid #cbd5e1;background:#f8fafc;color:#475569;display:grid;place-items:center;font-size:12px;pointer-events:none;box-shadow:0 1px 2px #0f172a14}.screen .btn,.modal .btn{min-height:44px;padding:12px 18px;font-size:16px}.screen .btn-icon-only,.modal .btn-icon-only{width:44px;height:44px}.field-row{display:flex;gap:8px}.form-grid--payment-modal{gap:9px}.form-grid--payment-modal .field-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(150px,.82fr);gap:8px;align-items:stretch}.payment-modal-actions{display:grid;gap:8px}.payment-modal-actions--double{grid-template-columns:repeat(2,minmax(0,1fr))}.payment-modal-actions--triple{grid-template-columns:repeat(3,minmax(0,1fr))}.payment-modal-actions .btn{height:44px;min-height:44px;width:100%;padding-block:0}.payment-modal-actions .btn.btn-ghost,.payment-modal-actions .btn.btn-primary{font-size:15px}.preset-chip-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px}.preset-chip-grid button{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatars-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.avatar-option{border-radius:16px;background:#f9fafb;border:1px solid rgba(209,213,219,1);width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.avatar-option.selected{background:var(--accent-soft);border-color:var(--accent);transform:translateY(-1px)}.chip-input{display:flex;flex-wrap:wrap;gap:6px;align-items:center;border-radius:14px;background:#f9fafb;border:1px solid rgba(209,213,219,1);min-height:44px;padding:10px}.chip{border-radius:999px;background:#fff;border:1px solid rgba(209,213,219,1);padding:4px 8px;font-size:11px;display:inline-flex;align-items:center;gap:4px}.chip-selected{background:#bbf7d0b3;border-color:#22c55e;color:#065f46}.chip-remove{border:none;background:transparent;color:var(--text-soft);cursor:pointer}.chip-input input{border:none;outline:none;background:transparent;color:var(--text);font-size:15px;min-width:80px;flex:1}.help-card{background:#fff;border:1px solid rgba(209,213,219,1);border-radius:14px;overflow:hidden;box-shadow:0 12px 28px #0f172a0f}.help-card-toggle{width:100%;text-align:left;background:#f9fafb;border:none;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;gap:10px;cursor:pointer;font-size:13px;font-weight:700;color:#111827}.help-card-body{padding:12px 14px 14px;font-size:12px;color:#374151;line-height:1.55}.help-section-title{font-size:12px;font-weight:800;color:#111827;margin:10px 0 6px}.help-list{margin:0;padding-left:18px}.help-list li{margin:4px 0}.group-header .btn{min-height:40px;padding:8px 12px;font-size:13px}.group-header .btn.btn-icon-only,.group-header .btn-icon-only{width:40px;height:40px;padding:0}.payments-summary{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-top:4px;padding:10px 11px;border-radius:16px;background:#ffffffd6;border:1px solid rgba(209,213,219,.82);box-shadow:0 12px 26px #0f172a14}.payments-summary-label{font-size:11px;color:#9ca3af}.payments-summary-actions{display:flex;align-items:center;gap:8px;flex:0 0 auto}.amount-large{font-size:20px;font-weight:700}.payments-list{margin-top:6px}.day-group{margin-top:10px}.day-label{font-size:11px;color:var(--text-soft);margin-bottom:4px}.payment-card{border-radius:16px;background:#fff;border:1px solid rgba(209,213,219,1);border-left:3px solid rgba(52,211,153,.7);width:100%;padding:8px 9px;margin-bottom:6px;display:flex;justify-content:space-between;gap:6px;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 10px 24px #0f172a0f}.payment-card:hover{border-color:#94a3b8;transform:translateY(-1px);box-shadow:0 12px 30px #0f172a1f}.payment-main{display:flex;flex-direction:column;gap:2px;align-items:flex-start;text-align:left}.payment-title{font-size:15px;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payment-meta{font-size:11px;color:var(--text-soft)}.payment-amount{text-align:right;font-size:13px}.settlement-list{margin-top:6px}.settlement-row{border-radius:14px;background:#fff;border:1px solid rgba(209,213,219,1);width:100%;padding:10px 12px;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;font-size:12px;box-shadow:0 10px 24px #0f172a0d}.settlement-row.done{opacity:.55}.settlement-row.done .settlement-person span{text-decoration:line-through}.settlement-person{display:flex;align-items:center;gap:8px}.checkbox{width:22px;height:22px;border-radius:6px;border:2px solid rgba(148,163,184,.9);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer}.checkbox.checked{background:var(--accent);border-color:var(--accent);color:#022c22}.todo-list{margin-top:6px;display:flex;flex-direction:column;gap:6px}.todo-folder-panel{border-radius:16px;background:#fff;border:1px solid rgba(209,213,219,1);padding:6px 8px;margin-bottom:6px;box-shadow:0 10px 24px #0f172a0d}.todo-folder-row{display:flex;align-items:center;gap:8px}.todo-folder-guide-wrap{position:relative;display:inline-flex;flex:0 0 auto;overflow:visible}.todo-folder-scroll{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px;flex:1;min-width:0}.todo-input-bar{display:flex;align-items:stretch;width:100%;margin-bottom:6px;border:1px solid rgba(209,213,219,1);border-radius:14px;background:#fff;overflow:hidden;box-shadow:0 10px 24px #0f172a0d}.todo-input-wrap{position:relative;overflow:visible}.todo-input-bar .field-control{min-width:0;flex:1;border:none;box-shadow:none;border-radius:0;background:transparent;padding-left:12px;padding-right:12px}.todo-input-bar .field-control:focus{box-shadow:none}.todo-add-btn{flex:0 0 auto;min-width:62px;border:none;border-left:1px solid rgba(209,213,219,1);border-radius:0;background:#22c55e1f;color:#166534;font-weight:700;padding:0 14px}.todo-add-btn:hover{background:#22c55e2e}.todo-guide-bubble{position:absolute;top:calc(100% + 6px);right:0;width:max-content;max-width:min(180px,calc(100vw - 18px));padding:8px 10px 10px;border-radius:16px;border:1px solid rgba(148,163,184,.72);background:#fffffffa;color:#9ca3af;font-size:13px;font-weight:800;line-height:1.08;box-shadow:0 10px 18px #0f172a2e;z-index:3}.todo-guide-bubble:before{content:"";position:absolute;right:14px;top:-16px;width:0;height:0;border-left:9px solid transparent;border-right:9px solid transparent;border-bottom:18px solid rgba(148,163,184,.72);filter:drop-shadow(0 -1px 1px rgba(148,163,184,.16))}.todo-guide-bubble:after{content:"";position:absolute;right:15px;top:-15px;width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-bottom:17px solid rgba(255,255,255,.98);filter:drop-shadow(0 -1px 2px rgba(15,23,42,.1))}.todo-guide-bubble--add{max-width:min(190px,calc(100vw - 18px))}.todo-guide-bubble-text{color:#9ca3af;text-align:center;white-space:pre-line}.todo-item{border-radius:0;background:transparent;border:none;width:100%;padding:10px 4px 10px 6px;display:flex;justify-content:space-between;align-items:center;font-size:13px;border-bottom:1px solid rgba(229,231,235,1);box-shadow:0 8px 20px #0f172a0d}.todo-item.done{opacity:.5;text-decoration:line-through}.todo-text{display:flex;align-items:flex-start;gap:8px;min-width:0;flex:1}.todo-text-body{min-width:0;display:flex;flex-direction:column;gap:2px}.todo-text-title{word-break:break-word;line-height:1.4}.todo-actions{display:flex;justify-content:center;align-items:center;flex-shrink:0;align-self:center;padding-top:0}.todo-folder-label{font-size:11px;color:#6b7280f2;line-height:1.1;text-align:right;max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:0}.toast{position:fixed;left:50%;bottom:84px;transform:translate(-50%);padding:9px 12px;border-radius:999px;background:#111827;box-shadow:0 14px 40px #0f172a66;color:#f9fafb;font-size:12px;display:flex;align-items:center;gap:8px;z-index:60}.toast-accent{width:6px;height:6px;border-radius:999px;background:var(--accent)}.memo-fab{position:fixed;bottom:24px;right:20px;width:52px;height:52px;border-radius:999px;background:#16a34a;color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #16a34a66;z-index:50;cursor:pointer;border:none}.memo-history-panel{position:fixed;bottom:82px;right:14px;width:56px;background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 2px 8px #0f172a1f;padding:4px 7px;z-index:49;display:flex;flex-direction:column;gap:2px;cursor:pointer}.memo-history-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:6px;border-bottom:1px solid #f3f4f6}.memo-history-row{display:flex;align-items:flex-start;gap:6px;padding:2px 0}.memo-history-checked{opacity:.45;text-decoration:line-through}.memo-fab-dot{position:absolute;top:8px;right:8px;width:8px;height:8px;border-radius:999px;background:#fbbf24;border:2px solid #16a34a}.memo-banner{display:flex;gap:10px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:10px 12px;margin-top:4px}.memo-banner-icon{font-size:18px;flex-shrink:0;line-height:1.4}.memo-banner-title{font-size:12px;font-weight:700;color:#92400e;margin-bottom:2px}.memo-banner-body{font-size:11px;color:#b45309;line-height:1.5}.memo-item-card{border:1px solid #e5e7eb;border-radius:10px;background:#fff;overflow:hidden}.memo-item-card.memo-item-checked{opacity:.55}.memo-item-header{display:flex;align-items:center;gap:8px;background:#f9fafb;padding:8px 10px;border-bottom:1px solid #e5e7eb}.memo-item-label{font-size:12px;font-weight:600;color:#6b7280}.memo-item-fields{display:flex;flex-direction:column;gap:0}.memo-field-row{display:flex;align-items:center;gap:8px;padding:7px 10px;border-bottom:1px solid #f3f4f6}.memo-field-row:last-child{border-bottom:none}.memo-field-label{font-size:11px;color:#9ca3af;width:52px;flex-shrink:0}.memo-field-input{flex:1;font-size:13px}.code-block{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:11px;padding:8px 9px;border-radius:10px;background:#f9fafb;border:1px solid rgba(209,213,219,1);word-break:break-all}.qr-box{margin-top:10px;border-radius:18px;padding:10px;background:#fff;border:1px solid rgba(209,213,219,1);display:flex;justify-content:center}.empty-state{text-align:center;padding:30px 12px 20px;color:var(--text-soft);font-size:13px}.empty-icon{font-size:32px;margin-bottom:8px;display:flex;align-items:center;justify-content:center}.app-logo-mark{display:block;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.app-logo-mark--login{width:96px;height:96px;margin:0 auto 16px}.app-logo-mark--empty{width:72px;height:72px}.slide-fade-enter{animation:slideFadeIn .22s ease-out}@keyframes slideFadeIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}@media(max-width:480px){.app-shell{padding:max(2px,calc(env(safe-area-inset-top,0px) - 4px)) 9px 14px;gap:10px}.app-header{padding:4px 8px 8px}.app-title{flex:1}.app-title-main{font-size:24px;font-weight:900;white-space:nowrap}.app-title-sub{font-size:11px;white-space:nowrap}.screen{border-radius:24px;padding:10px 9px 5px;gap:10px}.group-card{padding:9px}.modal,.modal-card{max-width:100%;padding:12px 12px 18px;border-radius:22px 22px 0 0;max-height:min(88svh,680px)}.form-grid--payment-modal{gap:8px}.form-grid--payment-modal .field-row{grid-template-columns:minmax(0,1fr) minmax(140px,.75fr);gap:7px}.preset-chip-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:5px}.preset-chip-grid button{padding-inline:6px!important;font-size:11px!important}.group-detail-invite-bubble{width:min(320px,calc(100vw - 14px));font-size:12px;padding:12px 12px 14px}.payments-add-bubble{width:min(280px,calc(100vw - 14px));font-size:11px;padding:10px 10px 12px}}@media(max-width:360px){.app-shell{padding-inline:7px}.screen{padding-inline:8px}.form-grid--payment-modal .field-row{grid-template-columns:minmax(0,1fr) minmax(126px,.7fr)}.preset-chip-grid button{font-size:10px!important;padding-inline:5px!important}}
