*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}:root{--color-bg: #f0f2f5;--color-surface: #ffffff;--color-border: #e2e6ea;--color-text: #1a1f2e;--color-text-muted: #6b7280;--color-accent: #4f46e5;--color-accent-hover: #4338ca;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px}body{font-family:var(--font);font-size:.9375rem;line-height:1.6;color:var(--color-text);background:var(--color-bg)}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-hover)}h1{font-size:1.75rem;font-weight:700;line-height:1.2}h2{font-size:1.125rem;font-weight:600;line-height:1.3}h3{font-size:1rem;font-weight:600;line-height:1.3}.min-h-screen{min-height:100vh;display:flex;flex-direction:column}.main-content{max-width:860px;width:100%;margin:var(--space-8) auto;padding:0 var(--space-4);flex:1}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);height:56px;display:flex;align-items:center;padding:0 var(--space-6)}.nav-content{max-width:860px;width:100%;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.nav-brand{font-size:1.125rem;font-weight:700;color:var(--color-text);text-decoration:none;letter-spacing:-.02em}.nav-links{display:flex;align-items:center;gap:var(--space-3)}.nav-links a{font-size:.8125rem;font-weight:500;color:var(--color-text-muted);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:color .15s}.nav-links a:hover{color:var(--color-text)}.btn-primary,.btn-login,.btn-logout,.btn-ghost{display:inline-flex;align-items:center;gap:var(--space-2);padding:0 var(--space-4);height:36px;border:none;border-radius:var(--radius-md);font-family:var(--font);font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;transition:background .15s,opacity .15s;white-space:nowrap}.btn-primary,.btn-login{background:var(--color-accent);color:#fff}.btn-primary:hover,.btn-login:hover{background:var(--color-accent-hover);color:#fff}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-logout{background:transparent;color:var(--color-danger);border:1px solid var(--color-border)}.btn-logout:hover{background:#fef2f2;border-color:var(--color-danger)}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-bg);color:var(--color-text)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6)}.status-badge{display:inline-block;padding:2px var(--space-2);border-radius:99px;font-size:.75rem;font-weight:500;line-height:1.6;white-space:nowrap}.status-no_transactions{color:#6b7280;background:#f3f4f6}.status-waiting_for_partner{color:#92400e;background:#fef3c7}.status-in_progress{color:#1e40af;background:#dbeafe}.status-settled{color:#14532d;background:#dcfce7}.home-page{display:flex;flex-direction:column;gap:var(--space-6)}.sheets-header{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-4)}.sheets-header h1{margin:0}.sheets-list{display:flex;flex-direction:column;gap:var(--space-3)}.sheet-card{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);text-decoration:none;color:inherit;transition:box-shadow .12s,border-color .12s}.sheet-card:hover{border-color:#c7d0db;box-shadow:0 2px 8px #00000012;color:inherit}.sheet-card-body{display:flex;flex-direction:column;gap:var(--space-1)}.sheet-card-title{font-size:1rem;font-weight:600;color:var(--color-text)}.sheet-card-meta{font-size:.8125rem;color:var(--color-text-muted)}.no-sheets{color:var(--color-text-muted);font-size:.9375rem;padding:var(--space-10) 0;text-align:center}.login-page,.login-prompt{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-10) var(--space-8);text-align:center;max-width:400px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.login-page h1,.login-prompt h1{margin:0}.login-page p,.login-prompt p{color:var(--color-text-muted);margin:0}.callback-page{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-muted)}.profile-page{display:flex;flex-direction:column;gap:var(--space-6)}.profile-page h1{margin:0}.profile-details{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.profile-field{display:flex;align-items:center;padding:var(--space-4) var(--space-5);gap:var(--space-8)}.profile-field+.profile-field{border-top:1px solid var(--color-border)}.field-label{font-size:.8125rem;font-weight:500;color:var(--color-text-muted);width:80px;flex-shrink:0}.field-value{color:var(--color-text)}.create-sheet-page{display:flex;flex-direction:column;gap:var(--space-6)}.create-sheet-page h1{margin:0}.create-sheet-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5);max-width:480px}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-field label,.form-field legend{font-size:.8125rem;font-weight:500;color:var(--color-text-muted);border:none;padding:0}.form-field input[type=text],.form-field input[type=email]{width:100%;height:40px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font);font-size:.9375rem;color:var(--color-text);background:var(--color-surface);transition:border-color .15s,box-shadow .15s}.form-field input[type=text]:focus,.form-field input[type=email]:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #4f46e51f}.form-field fieldset{border:none;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.form-field fieldset label{display:flex;align-items:center;gap:var(--space-2);font-size:.9375rem;font-weight:400;color:var(--color-text);cursor:pointer}.form-field input[type=radio]{accent-color:var(--color-accent);width:16px;height:16px;cursor:pointer}.field-error{font-size:.8125rem;color:var(--color-danger)}.form-error{font-size:.875rem;color:var(--color-danger);background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);padding:var(--space-3) var(--space-4)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2)}.sheet-detail-page{display:flex;flex-direction:column;gap:var(--space-6)}.sheet-detail-header{display:flex;flex-direction:column;gap:var(--space-2)}.sheet-detail-header a{font-size:.8125rem;color:var(--color-text-muted);display:inline-flex;align-items:center;gap:var(--space-1)}.sheet-detail-header a:hover{color:var(--color-text)}.sheet-detail-header h1{margin:0}.sheet-detail-meta{font-size:.875rem;color:var(--color-text-muted)}.sheet-detail-transactions{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.sheet-detail-transactions h2{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);margin:0}.sheet-detail-transactions p{padding:var(--space-5);color:var(--color-text-muted)}.transactions-table{width:100%;border-collapse:collapse;font-size:.875rem}.transactions-table thead th{padding:var(--space-3) var(--space-4);text-align:left;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.transactions-table thead th:last-child,.transactions-table thead th:nth-child(3){text-align:right}.transactions-table tbody tr:nth-child(2n){background:#f8f9fb}.transactions-table tbody td{padding:var(--space-3) var(--space-4);color:var(--color-text);vertical-align:middle}.transactions-table tbody td:nth-child(3),.transactions-table tbody td:last-child{text-align:right}.transactions-table tbody td:nth-child(3){font-variant-numeric:tabular-nums;font-weight:500}.settlement-summary{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);display:flex;flex-direction:column;gap:var(--space-3)}.settlement-summary h3{color:var(--color-text-muted);font-size:.8125rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;margin:0}.settlement-summary p{font-size:1.25rem;font-weight:600;color:var(--color-accent);margin:0}.settlement-even p{color:var(--color-text-muted)}.error{color:var(--color-danger)}.message{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:.875rem}.message.success{background:#dcfce7;color:#14532d;border:1px solid #bbf7d0}.message.error{background:#fef2f2;color:var(--color-danger);border:1px solid #fecaca}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--color-text-muted)}.form-group{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5)}.form-group label{font-size:.8125rem;font-weight:500;color:var(--color-text-muted)}.form-group input,.form-group textarea{width:100%;height:40px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font);font-size:.9375rem;color:var(--color-text);background:var(--color-surface);transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #4f46e51f}.modal-backdrop{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-8);width:min(760px,95vw);max-height:90vh;display:flex;flex-direction:column;gap:var(--space-6)}.modal-title{font-size:1.125rem;font-weight:600;margin:0}.modal-drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:var(--space-10);text-align:center;color:var(--color-text-muted);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3)}.modal-review-scroll{overflow-y:auto;max-height:50vh;border:1px solid var(--color-border);border-radius:var(--radius-md)}.review-table{width:100%;border-collapse:collapse;font-size:.875rem}.review-table thead th{text-align:left;padding:var(--space-2) var(--space-3);background:var(--color-bg);font-size:.8125rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0}.review-table tbody td{padding:var(--space-2) var(--space-3);border-top:1px solid var(--color-border);vertical-align:top}.review-row-included{background:#f5f3ff}.review-amount{text-align:right;font-variant-numeric:tabular-nums}.review-display-name{display:flex;flex-direction:column;gap:var(--space-1);margin-top:var(--space-2)}.review-display-name label{font-size:.8125rem;color:var(--color-text-muted)}.review-display-name input,.review-display-name select{height:32px;padding:0 var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text);background:var(--color-surface)}.sheet-upload-bar{margin-bottom:var(--space-6)}.settlement-breakdown-btn{align-self:flex-start;height:30px;font-size:.8125rem}.breakdown-modal{width:min(560px,95vw)}.breakdown-section{display:flex;flex-direction:column;gap:var(--space-2)}.breakdown-section h3{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin:0}.breakdown-table{width:100%;border-collapse:collapse;font-size:.9375rem}.breakdown-table td{padding:var(--space-1) 0;color:var(--color-text)}.breakdown-table .breakdown-amount{text-align:right;font-variant-numeric:tabular-nums}.breakdown-table tr.breakdown-total td{padding-top:var(--space-2);border-top:1px solid var(--color-border);font-weight:600}
