:root{--bg: #f5f1e8;--surface: #fffdf8;--surface-strong: #ffffff;--surface-muted: #efe6d5;--line: #d7c8ae;--line-strong: #c1ae90;--text: #201714;--text-muted: #685749;--brand: #c45d2d;--brand-strong: #9d4320;--brand-soft: #f4d3b4;--danger: #bc3b3b;--success: #1f7a49;--shadow: 0 18px 50px rgba(56, 36, 18, .12);--radius-lg: 20px;--radius-md: 12px;--radius-sm: 8px;--font-body: "Avenir Next", "Trebuchet MS", "Segoe UI", sans-serif;--font-display: "Palatino Linotype", "Book Antiqua", Georgia, serif}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100%}body{min-height:100vh;font-family:var(--font-body);color:var(--text);background:radial-gradient(circle at top left,rgba(244,211,180,.9),transparent 32%),radial-gradient(circle at top right,rgba(196,93,45,.16),transparent 24%),linear-gradient(180deg,#fbf7ef 0%,var(--bg) 100%)}a{color:inherit}button,input,select,textarea{font:inherit}button{cursor:pointer}[hidden]{display:none!important}.screen{min-height:100vh}.loading-screen{display:grid;place-items:center;padding:48px 20px}.loading-orb{width:56px;height:56px;border-radius:50%;border:4px solid rgba(196,93,45,.18);border-top-color:var(--brand);animation:spin .7s linear infinite}.auth-layout{display:grid;place-items:center;padding:32px 20px}.auth-box{width:min(100%,430px);background:#fffdf8f5;border:1px solid rgba(193,174,144,.8);border-radius:28px;padding:38px 34px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;margin-bottom:16px;border-radius:14px;background:linear-gradient(135deg,var(--brand) 0%,#db8c52 100%);color:#fff;font-size:21px;font-weight:700}.logo-title{margin:0 0 8px;font-family:var(--font-display);font-size:34px;line-height:1}.logo-subtitle{margin:0 0 26px;color:var(--text-muted);font-size:14px}.auth-tabs{display:flex;gap:8px;margin-bottom:18px}.tab-btn,.ghost-link,.btn-primary,.btn-outline,.btn-danger,.share-type-btn,.icon-btn{transition:background-color .18s ease,color .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease}.tab-btn{flex:1;border:1px solid var(--line);border-radius:999px;background:#ffffffb8;color:var(--text-muted);padding:10px 14px}.tab-btn.active{background:var(--text);border-color:var(--text);color:#fff}.auth-form,.stack-form{display:flex;flex-direction:column;gap:12px}.field,.textarea-field,.select-field{width:100%;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--text);padding:12px 14px;outline:none}.field:focus,.textarea-field:focus,.select-field:focus{border-color:var(--brand);box-shadow:0 0 0 4px #c45d2d1f}.select-field{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-muted) 50%),linear-gradient(135deg,var(--text-muted) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:32px}.btn-primary,.btn-outline,.btn-danger,.icon-btn{border-radius:999px;border:1px solid transparent;font-weight:600}.btn-primary{background:linear-gradient(135deg,var(--brand) 0%,#d47a41 100%);color:#fff;padding:11px 18px;box-shadow:0 10px 24px #c45d2d38}.btn-primary:hover,.btn-outline:hover,.btn-danger:hover,.icon-btn:hover,.tab-btn:hover{transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--brand-strong);border-color:var(--line-strong);padding:10px 16px}.btn-danger{background:transparent;color:var(--danger);border-color:#bc3b3b59;padding:8px 14px}.icon-btn{width:40px;height:40px;background:#fffc;border-color:var(--line);color:var(--text)}.ghost-link{border:none;background:transparent;color:var(--brand-strong);padding:0}.helper-text,.muted{color:var(--text-muted);font-size:13px}.error-msg,.success-msg{min-height:18px;font-size:13px}.error-msg{color:var(--danger)}.success-msg{color:var(--success)}.app-shell{min-height:100vh}.app-header{position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fbf7efd1;border-bottom:1px solid rgba(193,174,144,.7)}.app-header__inner{max-width:1100px;margin:0 auto;padding:18px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px}.brand-block{display:flex;align-items:center;gap:14px}.brand-block__title{margin:0;font-family:var(--font-display);font-size:28px}.brand-block__subtitle{margin:0;font-size:13px;color:var(--text-muted)}.app-header__right{display:flex;align-items:center;gap:12px}.menu-wrapper{position:relative}.header-dropdown{position:absolute;top:calc(100% + 12px);right:0;min-width:240px;padding:10px;border-radius:18px;border:1px solid var(--line);background:#fffdf8fa;box-shadow:var(--shadow)}.dropdown-label{margin:0 0 8px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.dropdown-stack{display:flex;flex-direction:column;gap:8px}.app-main{max-width:1100px;margin:0 auto;padding:28px 20px 40px;display:grid;gap:20px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:20px;align-items:start}.panel,.hero-panel{border:1px solid rgba(193,174,144,.78);border-radius:24px;background:#fffdf8eb;box-shadow:var(--shadow)}.panel{padding:22px}.hero-panel{padding:26px;background:linear-gradient(135deg,#fff9f0f5,#f4e9d5eb),var(--surface)}.panel-title,.section-heading{margin:0 0 14px;font-size:18px}.section-heading{font-family:var(--font-display);font-size:24px}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.debt-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.debt-col h3{margin:0 0 10px;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.debt-col h3[data-tone=owe]{color:var(--danger)}.debt-col h3[data-tone=owed]{color:var(--success)}.debt-list{display:flex;flex-direction:column;gap:8px}.debt-row{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:12px 14px;border-radius:16px;font-size:14px}.debt-row.owe{background:#bc3b3b14;color:#872727}.debt-row.owed{background:#1f7a491a;color:#165735}.debt-row strong{font-weight:700}.validation-hints{display:flex;flex-wrap:wrap;gap:10px}.hint{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:var(--surface-muted);color:var(--text-muted);font-size:12px}.hint.ok{background:#1f7a491f;color:#165735}.hint.err{background:#bc3b3b1a;color:#872727}.expense-form,.participant-grid,.expense-list{display:flex;flex-direction:column;gap:14px}.form-row{display:grid;grid-template-columns:minmax(0,1fr) 170px;gap:12px}.participants-table-wrap{overflow:auto;border:1px solid var(--line);border-radius:18px;background:#ffffffb8}.participants-table{width:100%;border-collapse:collapse}.participants-table th,.participants-table td{padding:10px 12px;text-align:left;border-bottom:1px solid rgba(193,174,144,.5)}.participants-table th{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.participants-table tr:last-child td{border-bottom:none}.share-cell{display:flex;gap:8px;align-items:center}.share-type-btn{border:1px solid transparent;padding:8px 10px;border-radius:999px;background:#ffffffd1}.share-type-btn[data-type=relative]{color:#0a5786;border-color:#0a57862e;background:#79bfe324}.share-type-btn[data-type=absolute]{color:#165735;border-color:#1f7a492e;background:#1f7a491a}.remove-btn{border:none;background:transparent;color:var(--text-muted);font-size:20px}.form-actions,.modal-actions,.expense-footer{display:flex;gap:10px;align-items:center}.expense-card{padding:18px;border:1px solid rgba(193,174,144,.7);border-radius:20px;background:#ffffffb8}.expense-card:hover{border-color:#c45d2d94}.expense-card__top,.expense-card__meta{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.expense-card__title{flex:1;font-weight:700}.expense-card__amount{color:var(--brand-strong);font-size:16px;font-weight:700}.expense-card__line{margin-top:8px;color:var(--text-muted);font-size:13px}.empty-state{padding:28px;text-align:center;color:var(--text-muted);border:1px dashed var(--line-strong);border-radius:18px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;padding:20px;background:#1c100861;display:grid;place-items:center;z-index:20}.modal-card{width:min(100%,420px);border-radius:24px;padding:26px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow)}.modal-card h3{margin:0 0 8px}.status-banner{padding:12px 14px;border-radius:16px;background:#bc3b3b1a;color:#872727}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr}}@media(max-width:700px){.app-header__inner,.app-main{padding-left:14px;padding-right:14px}.form-row,.debt-columns{grid-template-columns:1fr}.auth-box,.panel,.hero-panel,.modal-card{border-radius:20px;padding:18px}}
