:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#18201d;background:#f7faf9;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #f7faf9;--surface: #ffffff;--surface-strong: #eef7f3;--text: #18201d;--muted: #66736e;--border: #d6e2dc;--primary: #008f7a;--primary-dark: #006f60;--danger: #c83232;--coral: #f05d5e;--gold: #f6c85f;--focus: #5e8cff;--shadow: 0 16px 38px rgba(24, 32, 29, .12)}*{box-sizing:border-box}html{min-height:100%;background:var(--bg)}body{min-width:320px;min-height:100vh;margin:0;background:var(--bg)}button,input,select,textarea{font:inherit;letter-spacing:0}button,a{-webkit-tap-highlight-color:transparent}img{display:block;max-width:100%}h1,h2,h3,p{margin:0}h1{font-size:2rem;line-height:1.08}h2{font-size:1.25rem;line-height:1.2}h3{font-size:1rem;line-height:1.25}a{color:inherit;text-decoration:none}label,.field-group{display:grid;gap:.45rem;color:var(--text);font-weight:700}input,select,textarea{width:100%;min-height:46px;border:1px solid var(--border);border-radius:8px;padding:.75rem .85rem;background:var(--surface);color:var(--text);outline:none}textarea{resize:vertical}input:focus,select:focus,textarea:focus,button:focus-visible,a:focus-visible{outline:0;box-shadow:0 0 0 2px #008f7a29}.auth-shell,.app-shell{width:min(100%,760px);margin:0 auto;padding:1rem}.auth-shell{min-height:100vh;display:grid;align-items:center}.auth-panel,.section,.notice-block,.user-strip,.group-card,.expense-item,.member-row,.share-box,.settlement-result{border:1px solid var(--border);border-radius:8px;background:var(--surface);box-shadow:var(--shadow)}.auth-panel{display:grid;gap:1.1rem;padding:1rem}.auth-photo{width:100%;height:180px;object-fit:cover;border-radius:8px}.brand-block{display:grid;gap:.55rem}.brand-block p:last-child,.muted,.group-card p,.expense-body p,.member-row p,.notice-block p,.user-strip p{color:var(--muted)}.eyebrow{color:var(--primary);font-size:.78rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.divider{display:grid;grid-template-columns:1fr auto 1fr;gap:.75rem;align-items:center;color:var(--muted)}.divider:before,.divider:after{height:1px;background:var(--border);content:""}.stack{display:grid;gap:.9rem}.button{min-height:44px;border:1px solid var(--primary);border-radius:8px;padding:.72rem 1rem;background:var(--primary);color:#fff;font-weight:800;cursor:pointer;text-align:center}.button:hover{background:var(--primary-dark)}.button:disabled{border-color:var(--border);background:#e4ebe7;color:#87918d;cursor:not-allowed}.button-outline{background:var(--surface);color:var(--primary)}.button-outline:hover{background:var(--surface-strong)}.button-danger{border-color:#c8323238;background:#c8323214;color:var(--danger)}.button-danger:hover{background:#c8323224}.button-ghost{border-color:transparent;background:transparent;color:var(--text)}.button-ghost:hover{background:var(--surface-strong)}.full-width{width:100%}.status{border-radius:8px;padding:.8rem;font-weight:700}.status-error{border:1px solid rgba(200,50,50,.28);background:#c8323214;color:var(--danger)}.status-ok{border:1px solid rgba(0,143,122,.22);background:#008f7a14;color:var(--primary-dark)}.top-bar{display:flex;gap:1rem;align-items:center;justify-content:space-between;margin-bottom:1rem}.user-strip,.notice-block{display:flex;gap:.9rem;align-items:center;justify-content:space-between;margin-bottom:1rem;padding:.9rem}.notice-block>div{min-width:0}.notice-block strong,.status{overflow-wrap:anywhere}.avatar,.avatar-image{display:inline-grid;flex:0 0 auto;width:44px;height:44px;place-items:center;border-radius:8px;background:var(--primary);color:#fff;font-weight:900;object-fit:cover}.inline-actions{display:flex;flex-wrap:wrap;gap:.55rem}.section{display:grid;gap:1rem;margin:1rem 0;padding:1rem}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:1rem}.heading-actions{display:flex;flex:0 0 auto;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:flex-end}.section-heading span{display:inline-grid;min-width:34px;height:34px;place-items:center;border-radius:8px;background:var(--surface-strong);color:var(--primary-dark);font-weight:900}.cover-preview{width:100%;height:160px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.empty-state{display:grid;gap:.8rem;color:var(--muted)}.empty-state img{width:100%;height:150px;object-fit:cover;border-radius:8px}.group-list,.expense-list,.member-list,.balance-list,.transaction-list{display:grid;gap:.85rem}.group-card{overflow:hidden}.group-card>img{width:100%;height:148px;object-fit:cover}.group-card-body{display:grid;gap:.75rem;padding:.9rem}.back-button{margin-bottom:.75rem}.group-hero{position:relative;min-height:220px;display:grid;align-items:end;overflow:hidden;border-radius:8px;background:#18201d}.group-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.76}.group-hero:after{position:absolute;inset:0;background:linear-gradient(180deg,#18201d1a,#18201dc7);content:""}.group-hero>div{position:relative;z-index:1;display:grid;gap:.45rem;padding:1rem;color:#fff}.group-hero .eyebrow,.plain-link{color:#fff}.plain-link{width:fit-content;border:0;border-bottom:1px solid rgba(255,255,255,.72);padding:0;background:transparent;cursor:pointer;font-weight:800}.tabs{position:sticky;top:0;z-index:5;display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem;margin:1rem 0;padding:.35rem;border:1px solid var(--border);border-radius:8px;background:#f7faf9f0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.tab{min-height:42px;border:0;border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;font-weight:900}.tab.active{background:var(--primary);color:#fff}.form-sentence{display:inline;line-height:2.4;color:var(--text);font-weight:700}.form-sentence select{display:inline-block;width:auto;min-width:120px;min-height:40px;margin:0 .2rem;padding:.45rem .65rem}.chip-grid{display:flex;flex-wrap:wrap;gap:.5rem}.chip{min-height:38px;border:1px solid var(--border);border-radius:8px;padding:.45rem .7rem;background:var(--surface);color:var(--text);cursor:pointer;font-weight:800}.chip.selected{border-color:var(--primary);background:var(--surface-strong);color:var(--primary-dark)}.custom-split{display:grid;gap:.75rem;padding:.75rem;border:1px dashed var(--border);border-radius:8px;background:#fbfefd}.expense-item{overflow:hidden}.expense-photo{width:100%;height:140px;object-fit:cover}.expense-body{display:grid;gap:.55rem;padding:.9rem}.expense-title-row,.balance-row{display:flex;gap:.75rem;align-items:flex-start;justify-content:space-between}.expense-title-row strong,.group-card-body strong{white-space:nowrap}.note-text{border-left:3px solid var(--gold);padding-left:.65rem}.member-row,.balance-row,.transaction-row{display:flex;gap:.75rem;align-items:center;padding:.85rem}.member-row>div{min-width:0;flex:1}.member-row p,.member-row strong,.share-box p{overflow-wrap:anywhere}.share-box{display:grid;gap:.75rem;padding:.9rem}.share-box p{padding:.65rem;border-radius:8px;background:var(--surface-strong)}.share-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.55rem}.share-icon-button{display:grid;min-height:48px;place-items:center;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--primary-dark);cursor:pointer;text-decoration:none}.share-icon-button.primary{border-color:var(--primary);background:var(--primary);color:#fff}.share-icon-button:hover{background:var(--surface-strong)}.share-icon-button.primary:hover{background:var(--primary-dark)}.share-icon-button .app-icon{width:24px;height:24px}.settlement-actions{display:grid;grid-template-columns:1fr;gap:.65rem}.settlement-result{display:grid;gap:.85rem;padding:.9rem}.balance-row,.transaction-row{border:1px solid var(--border);border-radius:8px;background:#fbfefd;box-shadow:none}.positive{color:var(--primary-dark)}.negative{color:var(--danger)}@media(min-width:680px){.auth-panel{grid-template-columns:1fr 1fr;align-items:start}.auth-photo,.brand-block{grid-column:span 2}.settlement-actions{grid-template-columns:1fr 1fr}.group-list{grid-template-columns:repeat(2,minmax(0,1fr))}}body{background:var(--surface)}.app-shell{width:min(100%,520px);min-height:100vh;margin:0 auto;padding:0;background:var(--surface);animation:screen-slide-in .22s cubic-bezier(.22,1,.36,1) backwards}.with-bottom-nav{padding-bottom:104px}@keyframes screen-slide-in{0%{opacity:0;transform:translate(22px)}to{opacity:1;transform:translate(0)}}@keyframes panel-slide-in{0%{opacity:0;transform:translate(14px)}to{opacity:1;transform:translate(0)}}@keyframes sheet-slide-in{0%{opacity:.96;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.mobile-top-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.25rem .75rem}.mobile-top-bar h1{font-size:2.35rem}.brand-heading{display:flex;align-items:center;gap:.75rem}.brand-heading img{width:48px;height:48px;border-radius:8px}.brand-heading h1{font-size:2rem}.avatar-button{border:0;border-radius:8px;padding:0;background:transparent;cursor:pointer}.content-section,.section{display:grid;gap:1rem;margin:0;padding:1.1rem 1.25rem;border:0;border-radius:0;background:var(--surface);box-shadow:none;animation:panel-slide-in .18s ease-out backwards}.content-section .section-heading h2{color:var(--muted);font-size:.95rem;font-weight:900;text-transform:uppercase}.notice-block,.status{margin:.75rem 1.25rem;box-shadow:none}.group-list{display:grid;gap:0}.group-list-item{display:grid;grid-template-columns:62px 1fr;gap:.85rem;align-items:center;width:100%;min-height:82px;border:0;border-bottom:1px solid var(--border);border-radius:0;padding:.75rem 0;background:var(--surface);color:var(--text);cursor:pointer;text-align:left}.group-list-item>img{width:62px;height:62px;border-radius:8px;object-fit:cover}.group-list-body{display:flex;min-width:0;align-items:center;justify-content:space-between;gap:.75rem}.group-list-body span:first-child{display:grid;min-width:0;gap:.2rem}.group-list-body strong{overflow:hidden;font-size:1.08rem;text-overflow:ellipsis;white-space:nowrap}.group-list-body small{color:var(--muted)}.group-total{color:var(--primary-dark);font-weight:900;white-space:nowrap}.mobile-hero{min-height:260px;border-radius:0}.mobile-hero>.hero-actions{position:absolute;inset:1rem 1rem auto;z-index:2;display:flex;justify-content:space-between;padding:0}.mobile-hero>.hero-content{position:relative;z-index:1;display:grid;gap:.75rem;padding:1.25rem;color:#fff}.round-button,.icon-button{display:inline-grid;width:46px;height:46px;place-items:center;border:0;border-radius:8px;background:#fffffff0;color:var(--text);cursor:pointer;font-size:1.35rem;font-weight:900}.text-back-button{display:inline-grid;min-height:42px;place-items:center;border:0;border-radius:8px;padding:0 .85rem;background:#fffffff0;color:var(--text);cursor:pointer;font-weight:900}.people-pill{width:fit-content;min-height:38px;border:1px solid rgba(255,255,255,.35);border-radius:8px;padding:.45rem .8rem;background:#18201d94;color:#fff;cursor:pointer;font-weight:900}.expense-summary{display:grid;gap:.9rem;padding:1.1rem 1.25rem .4rem;animation:panel-slide-in .18s ease-out backwards}.expense-summary p{color:var(--text);font-size:1.05rem}.compact-button{width:fit-content;min-height:42px;padding-inline:1rem}.mobile-expense-list{gap:0}.expense-row{display:grid;grid-template-columns:48px 56px minmax(0,1fr) auto;gap:.75rem;align-items:center;width:100%;min-height:92px;border:0;border-bottom:1px solid var(--border);padding:.7rem 0;background:transparent;color:var(--text);cursor:pointer;text-align:left}.expense-row:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.expense-date{display:grid;justify-items:center;color:var(--muted);line-height:1.05;text-transform:lowercase}.expense-date span{font-size:.82rem}.expense-date strong{color:var(--muted);font-size:1.35rem;font-weight:500}.expense-thumb,.receipt-thumb{width:56px;height:56px;border-radius:4px}.expense-thumb{object-fit:cover}.receipt-thumb{display:grid;place-items:center;background:#eef0f4}.receipt-thumb span{width:24px;height:30px;border:1px solid #5f666b;background:linear-gradient(#5f666b,#5f666b) 5px 8px / 14px 1px no-repeat,linear-gradient(#5f666b,#5f666b) 5px 14px / 14px 1px no-repeat,linear-gradient(#5f666b,#5f666b) 5px 20px / 14px 1px no-repeat}.expense-main{display:grid;min-width:0;gap:.2rem}.expense-main h3{overflow:hidden;font-size:1.08rem;font-weight:500;text-overflow:ellipsis;white-space:nowrap}.expense-main p,.expense-main small{overflow:hidden;color:var(--muted);text-overflow:ellipsis;white-space:nowrap}.expense-balance{display:grid;justify-items:end;min-width:86px;gap:.15rem;text-align:right}.expense-balance span{font-size:.78rem;white-space:nowrap}.expense-balance strong{font-size:1.02rem;white-space:nowrap}.fab{position:fixed;right:max(1rem,calc((100vw - 520px)/2 + 1rem));bottom:82px;z-index:20;display:inline-flex;min-height:54px;align-items:center;gap:.55rem;border:0;border-radius:8px;padding:.8rem 1.15rem;background:var(--primary);color:#fff;box-shadow:0 14px 28px #006f6047;cursor:pointer;font-weight:900}.fab span{font-size:1.25rem;line-height:1}.bottom-nav{position:fixed;right:max(0rem,calc((100vw - 520px)/2));bottom:0;left:max(0rem,calc((100vw - 520px)/2));z-index:15;display:grid;grid-auto-flow:column;grid-auto-columns:1fr;border-top:1px solid var(--border);background:#fffffff5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.bottom-nav-item{display:grid;min-height:68px;place-items:center;gap:.2rem;border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:.82rem;font-weight:700}.bottom-nav-item span{font-size:.78rem;font-weight:900}.app-icon{width:24px;height:24px}.bottom-nav-item .app-icon{width:25px;height:25px}.bottom-nav-item.active{color:var(--primary-dark)}.modal-backdrop{position:fixed;inset:0;z-index:50;display:grid;align-items:end;background:#18201d6b}.modal-sheet{max-height:88vh;overflow:auto;border-radius:8px 8px 0 0;background:var(--surface);box-shadow:0 -18px 42px #18201d3d}.modal-header{position:sticky;top:0;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:var(--surface)}.modal-header .icon-button{width:38px;height:38px;background:var(--surface-strong)}.form-panel{padding:1rem 1.25rem 1.25rem}@media(min-width:680px){.app-shell{box-shadow:0 0 0 1px var(--border)}.group-list{grid-template-columns:1fr}.modal-backdrop{justify-items:center}.modal-sheet{width:min(100%,520px)}}.account-area{position:relative}.profile-menu{position:absolute;top:calc(100% + .55rem);right:0;z-index:25;display:grid;min-width:220px;gap:.35rem;border:1px solid var(--border);border-radius:8px;padding:.8rem;background:var(--surface);box-shadow:var(--shadow)}.profile-menu small{color:var(--muted);overflow-wrap:anywhere}.language-control{display:grid;gap:.35rem;border-top:1px solid var(--border);padding-top:.65rem;color:var(--text);font-size:.85rem;font-weight:800}.language-control select{width:100%;min-height:38px;border:1px solid var(--border);border-radius:8px;padding:0 .65rem;background:var(--surface);color:var(--text);font:inherit}.profile-menu button{min-height:40px;border:0;border-top:1px solid var(--border);padding:.65rem 0 0;background:transparent;color:var(--danger);cursor:pointer;font-weight:900;text-align:left}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.modal-backdrop{align-items:stretch;background:var(--surface);animation:fade-in .16s ease-out}.modal-sheet.editor-sheet{width:min(100%,520px);max-height:none;min-height:100dvh;margin:0 auto;border-radius:0;box-shadow:none;animation:sheet-slide-in .24s cubic-bezier(.22,1,.36,1) backwards}.modal-header{display:grid;grid-template-columns:1fr auto 1fr;min-height:64px;padding:.9rem 1.25rem}.modal-header h2{align-self:center;font-size:1.15rem;font-weight:600;text-align:center;white-space:nowrap}.modal-text-button,.modal-header-spacer{min-height:42px}.modal-text-button{border:0;background:transparent;color:var(--primary-dark);cursor:pointer;font-weight:900;text-align:left}.modal-text-button.strong{text-align:right}.editor-panel{padding:1.25rem}.editor-form{display:grid;gap:1.35rem}.group-name-row{display:grid;grid-template-columns:84px minmax(0,1fr);gap:1rem;align-items:start}.cover-picker{display:grid;width:84px;height:84px;place-items:center;overflow:hidden;border:1px dashed #c8ced2;border-radius:8px;background:#fbfcfd;color:var(--muted);cursor:pointer;font-weight:900}.cover-picker input{display:none}.cover-picker img{width:100%;height:100%;max-width:none;border-radius:8px;object-fit:cover}.cover-picker .app-icon{width:32px;height:32px}.cover-picker.loading{opacity:.72}.editor-field{display:grid;gap:.55rem}.editor-field>span,.field-group>span{color:var(--text);font-weight:700}.grow-field{min-width:0}.editor-input,.expense-description-input,.expense-amount-input{min-height:50px;border:0;border-bottom:2px solid var(--primary);border-radius:0;padding:.35rem 0;background:transparent;box-shadow:none}.editor-input:focus,.expense-description-input:focus,.expense-amount-input:focus{outline:0;border-bottom-color:var(--primary-dark);box-shadow:none}.editor-section{display:grid;gap:.85rem}.editor-section h3{color:var(--text);font-size:.98rem}.type-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.7rem}.type-option{display:grid;min-height:96px;place-items:center;gap:.35rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer;font-weight:800}.type-option span{color:var(--muted);font-size:.78rem}.type-option .app-icon{width:32px;height:32px;color:var(--text)}.type-option.selected{border-color:var(--primary);color:var(--primary-dark)}.type-option.selected .app-icon{color:var(--primary-dark)}.expense-editor-panel{padding-top:0}.expense-context{display:flex;align-items:center;gap:.55rem;min-height:54px;margin:0 -1.25rem 1.75rem;padding:0 1.25rem;border-bottom:1px solid var(--border);color:var(--text)}.expense-context strong{display:inline-flex;max-width:70%;min-height:34px;align-items:center;overflow:hidden;border:1px solid var(--border);border-radius:8px;padding:.25rem .75rem;color:var(--text);text-overflow:ellipsis;white-space:nowrap}.expense-main-fields{display:grid;grid-template-columns:64px minmax(0,1fr);gap:.85rem;align-items:center;margin-top:4.5rem}.expense-field-icon{display:grid;width:58px;height:58px;place-items:center;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);box-shadow:0 2px 4px #18201d1f;font-size:.72rem;font-weight:900;text-align:center}.expense-description-input{font-size:1.15rem}.expense-amount-input{border-bottom-color:var(--text);color:var(--text);font-size:2rem;font-weight:700}.split-pill{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center;width:fit-content;border:1px solid var(--border);border-radius:8px;padding:.55rem .75rem;box-shadow:0 2px 5px #18201d1f}.split-pill span{color:var(--text)}.split-pill select{width:auto;min-width:92px;min-height:32px;border:0;padding:0;color:var(--text);font-weight:700}.expense-extra-bar{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.45rem;margin-top:.3rem;padding-top:.9rem;border-top:1px solid var(--border)}.extra-action{display:grid;min-height:54px;gap:.15rem;place-items:center;border:0;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;font-weight:800}.extra-action .app-icon{width:28px;height:28px}.extra-action.active{background:var(--surface-strong);color:var(--primary-dark)}.expense-delete-button{margin-top:-.2rem}@media(prefers-reduced-motion:reduce){.app-shell,.content-section,.section,.expense-summary,.modal-backdrop,.modal-sheet.editor-sheet{animation:none}}@media(max-width:430px){.type-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.expense-main-fields{margin-top:2.5rem}}
