:root{--color-primary:#b89b72;--color-primary-hover:#d4bc96;--color-background:#f7f4ef;--color-surface:#fdfcfa;--color-text-main:#2c2c2c;--color-text-high:#1a1a1a;--color-border:#c8beb2;--color-muted:#9e9085;--color-success:#10b981;--color-success-soft:#f0fdf4;--color-blue:#3b82f6;--color-blue-soft:#eff6ff;--color-amber:#f59e0b;--color-amber-soft:#fffbeb;--color-purple:#8b5cf6;--color-purple-soft:#f5f3ff;--color-destructive:#ef4444;--font-heading:"Cormorant Garamond", serif;--font-body:"Jost", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-background);color:var(--color-text-main);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-text-high);margin-bottom:1rem}main{max-width:800px;margin:0 auto;padding:2rem}.contract-form{padding:0 0 4rem}.form-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:2rem;display:flex}.form-header h1{margin:0;font-size:2.25rem}.form-header-actions{align-items:center;gap:.75rem;display:flex}.draft-badge{color:#8a9e8c;font-size:.75rem;font-style:italic;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.form-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.625rem;margin-bottom:1.25rem;padding:1.75rem}.form-section h2{border-bottom:1px solid var(--color-border);color:var(--color-text-high);letter-spacing:.04em;margin-bottom:1.25rem;padding-bottom:.625rem;font-size:1.1rem}.load-property-section h2{margin-bottom:1rem}.empty-properties-hint{color:var(--color-muted,#9e9085);font-size:.875rem;line-height:1.6}.empty-properties-hint strong{color:var(--color-text-main);font-weight:500}.field{flex-direction:column;flex:1;gap:.375rem;min-width:0;display:flex}.field-row{gap:1rem;margin-bottom:1rem;display:flex}.field-row:last-child{margin-bottom:0}.form-section>.field{margin-bottom:1rem}.form-section>.field:last-child{margin-bottom:0}label{letter-spacing:.04em;color:var(--color-text-high);font-size:.8rem;font-weight:500}.required{color:var(--color-primary)}.hint{color:var(--color-muted,#9e9085);font-style:italic;font-weight:400}input[type=text],input[type=email],input[type=date],select{background:var(--color-background);border:1px solid var(--color-border);font-family:var(--font-body);color:var(--color-text-main);border-radius:.375rem;outline:none;width:100%;padding:.625rem .875rem;font-size:.9rem;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #b89b721f}.staging-section-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.625rem;display:flex}.staging-section-header h2{border:none;margin:0;padding:0}.btn-active{border-color:var(--color-primary);color:var(--color-primary);background:#b89b7212}.mini-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted,#9e9085);margin-bottom:.6rem;font-size:.72rem;font-weight:500}.selected-areas{margin-bottom:1.5rem}.selected-tags{flex-wrap:wrap;gap:.5rem;display:flex}.selected-tag{background:var(--color-primary);color:#fff;white-space:nowrap;border-radius:999px;align-items:center;gap:.35rem;padding:.3rem .75rem .3rem .875rem;font-size:.8rem;font-weight:500;display:inline-flex}.tag-remove{color:#ffffffbf;cursor:pointer;background:0 0;border:none;margin-left:.1rem;padding:0;font-size:1rem;line-height:1;transition:color .12s}.tag-remove:hover{color:#fff}.library-section{margin-top:.25rem}.library-chips{flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem;display:flex}.chip-wrapper{align-items:center;display:inline-flex;position:relative}.area-chip{background:var(--color-background);border:1px solid var(--color-border);font-family:var(--font-body);color:var(--color-text-main);cursor:pointer;white-space:nowrap;border-radius:999px;align-items:center;gap:.3rem;padding:.3rem .875rem;font-size:.8rem;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.area-chip:hover:not(:disabled){border-color:var(--color-primary);color:var(--color-text-high);background:#b89b7212}.area-chip:disabled{cursor:default;opacity:.7}.chip-selected{border-color:var(--color-primary);color:var(--color-primary);background:#b89b721a}.chip-check{opacity:.8;font-size:.7rem}.chip-edit-controls{border-left:1px solid var(--color-border);align-items:center;height:100%;margin-left:.25rem;padding-left:.2rem;display:flex}.chip-delete,.chip-move{color:var(--color-muted,#9e9085);cursor:pointer;background:0 0;border:none;height:100%;padding:0 .3rem;font-size:1.1rem;line-height:1;transition:color .12s,transform .1s}.chip-move:disabled{opacity:.2;cursor:default}.chip-move:not(:disabled):hover{color:var(--color-primary);transform:scale(1.15)}.chip-delete:hover{color:#c0392b}.add-area-row{flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1rem;display:flex}.add-area-input{flex:1;min-width:160px}.btn-muted{color:var(--color-muted,#9e9085);font-size:.75rem}.form-footer{text-align:center;margin-top:2rem}.submit-hint{color:var(--color-muted,#9e9085);margin-top:.75rem;font-size:.78rem}.sync-status{color:var(--color-muted,#9e9085);align-items:center;gap:.4rem;font-size:.72rem;font-style:italic;display:flex}.sync-dot{background:#8a9e8c;border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}@media (width<=600px){.field-row{flex-direction:column}.form-header h1{font-size:1.65rem}.form-section{padding:1.25rem}.add-area-row{flex-direction:column;align-items:stretch}}.success-screen{text-align:center;max-width:560px;margin:0 auto;padding:4rem 1rem}.success-icon{color:#fff;background:#8a9e8c;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 1.5rem;font-size:2rem;animation:.35s cubic-bezier(.34,1.56,.64,1) scaleIn;display:flex}@keyframes scaleIn{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.success-screen h1{margin-bottom:.25rem;font-size:2.25rem}.success-address{color:var(--color-muted,#9e9085);margin-bottom:2.5rem;font-size:.9rem}.success-links{text-align:left;flex-direction:column;gap:.75rem;margin-bottom:2.5rem;display:flex}.success-link{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-main);border-radius:.5rem;align-items:center;gap:1rem;padding:1rem 1.25rem;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .1s;display:flex}.success-link:hover{border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 2px 12px #b89b7226}.link-icon{flex-shrink:0;font-size:1.5rem}.success-link strong{margin-bottom:.15rem;font-weight:500;display:block}.success-link small{color:var(--color-muted,#9e9085);font-size:.775rem}.dashboard-container{padding:1rem 0;animation:.4s fadeIn}.period-selector{background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;width:fit-content;margin-bottom:2rem;padding:.25rem;display:flex}.period-btn{font-family:var(--font-body);color:var(--color-muted);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:500;transition:all .2s}.period-btn:hover{color:var(--color-text-main)}.period-btn.active{background:var(--color-primary);color:#fff;box-shadow:0 4px 12px #b89b7240}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem;display:grid}.kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;flex-direction:column;gap:.5rem;padding:1.5rem;transition:transform .2s,box-shadow .2s;display:flex}.kpi-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000a}.kpi-label{letter-spacing:.05em;text-transform:uppercase;color:var(--color-muted);font-size:.75rem;font-weight:600}.kpi-value{font-family:var(--font-heading);color:var(--color-text-high);font-size:2rem}.kpi-card.revenue{border-top:4px solid var(--color-success);background:var(--color-success-soft)}.kpi-card.pipeline{border-top:4px solid var(--color-blue);background:var(--color-blue-soft)}.kpi-card.proposals{border-top:4px solid var(--color-amber);background:var(--color-amber-soft)}.kpi-card.avg-deal{border-top:4px solid var(--color-purple);background:var(--color-purple-soft)}.chart-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;margin-bottom:2rem;padding:1.75rem}.chart-section h2{margin-bottom:1.5rem;font-size:1.1rem}.chart-container{width:100%;height:300px}.contract-list-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;padding:1.75rem;overflow-x:auto}.contract-list-section h2{margin-bottom:1.5rem;font-size:1.1rem}.contract-table{border-collapse:collapse;width:100%;font-size:.9rem}.contract-table th{text-align:left;border-bottom:2px solid var(--color-border);color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;padding:.75rem;font-size:.75rem;font-weight:600}.contract-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-main);padding:1rem .75rem}.contract-table tr:last-child td{border-bottom:none}.status-badge{letter-spacing:.04em;text-transform:uppercase;cursor:pointer;border-radius:999px;align-items:center;padding:.25rem .75rem;font-size:.7rem;font-weight:600;transition:opacity .2s;display:inline-flex;position:relative}.status-badge:hover{opacity:.8}.status-sent{background:var(--color-amber-soft);color:var(--color-amber);border:1px solid var(--color-amber)}.status-signed{background:var(--color-blue-soft);color:var(--color-blue);border:1px solid var(--color-blue)}.status-paid{background:var(--color-success-soft);color:var(--color-success);border:1px solid var(--color-success)}.status-cancelled{color:#666;background:#f5f5f5;border:1px solid #ddd}.status-menu{z-index:10;border:1px solid var(--color-border);background:#fff;border-radius:.5rem;flex-direction:column;gap:.25rem;min-width:120px;margin-bottom:.5rem;padding:.5rem;display:flex;position:absolute;bottom:100%;right:0;box-shadow:0 4px 12px #0000001a}.status-option{cursor:pointer;text-transform:capitalize;border-radius:.25rem;padding:.5rem .75rem;font-size:.75rem;transition:background .15s}.status-option:hover{background:var(--color-background)}@media (width<=600px){.header-nav{order:3;justify-content:center;width:100%;padding-top:.5rem}}.properties-view{padding:1rem 0;animation:.4s fadeIn}.type-filter{background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;width:fit-content;margin-bottom:2rem;padding:.25rem;display:flex}.properties-table-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.75rem;padding:1.75rem;overflow-x:auto}.properties-table-section h2{margin-bottom:1.5rem;font-size:1.1rem}.properties-table{border-collapse:collapse;width:100%;font-size:.9rem}.properties-table th{text-align:left;border-bottom:2px solid var(--color-border);color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;padding:.75rem;font-size:.75rem;font-weight:600}.properties-table td{border-bottom:1px solid var(--color-border);color:var(--color-text-main);padding:1rem .75rem}.properties-table tr:last-child td{border-bottom:none}.properties-table tbody tr.clickable-row{cursor:pointer;transition:background .15s}.properties-table tbody tr.clickable-row:hover{background:var(--color-background)}.type-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;align-items:center;padding:.2rem .6rem;font-size:.68rem;font-weight:600;display:inline-flex}.type-badge.proposal{background:var(--color-amber-soft);color:var(--color-amber);border:1px solid var(--color-amber)}.type-badge.contract{background:var(--color-purple-soft);color:var(--color-purple);border:1px solid var(--color-purple)}.panel-overlay{z-index:100;background:#00000059;animation:.2s fadeIn;position:fixed;inset:0}.edit-panel{background:var(--color-surface);border-left:1px solid var(--color-border);z-index:101;flex-direction:column;width:clamp(320px,480px,95vw);height:100vh;animation:.25s slideInRight;display:flex;position:fixed;top:0;right:0;overflow-y:auto;box-shadow:-4px 0 24px #00000014}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.edit-panel-inner{flex-direction:column;flex:1;gap:1.5rem;padding:2rem;display:flex}.panel-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.panel-header h2{font-family:var(--font-heading);margin-bottom:0;font-size:1.75rem}.panel-close{color:var(--color-muted);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1.5rem;line-height:1;transition:color .15s}.panel-close:hover{color:var(--color-text-high)}.panel-section{flex-direction:column;gap:1rem;display:flex}.panel-field-row{gap:1rem;display:flex}.panel-field-row .field{flex:1}.panel-footer{border-top:1px solid var(--color-border);background:var(--color-surface);align-items:center;gap:.75rem;padding:1.5rem 2rem;display:flex;position:sticky;bottom:0}.panel-footer-spacer{flex:1}.btn-destructive{border:1px solid var(--color-destructive);color:var(--color-destructive);font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:.375rem;padding:.5rem 1rem;font-size:.8rem;font-weight:500;transition:background .15s,color .15s}.btn-destructive:hover{background:var(--color-destructive);color:#fff}.delete-confirm{color:var(--color-destructive);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.delete-confirm span{font-weight:500}@media (width<=520px){.edit-panel{width:100vw}.panel-field-row{flex-direction:column}}.app-loading{background:var(--color-background);justify-content:center;align-items:center;min-height:100vh;display:flex}.app-wrapper{flex-direction:column;min-height:100vh;display:flex}.app-header{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 2rem;display:flex;position:relative}.header-nav{gap:2rem;display:flex;position:absolute;left:50%;transform:translate(-50%)}.nav-link{font-family:var(--font-body);letter-spacing:.05em;color:var(--color-muted,#9e9085);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.5rem 0;font-size:.8rem;font-weight:500;transition:color .2s,border-bottom .2s}.nav-link:hover{color:var(--color-text-main)}.nav-link.active{color:var(--color-primary);border-bottom:2px solid var(--color-primary)}.header-brand{font-family:var(--font-body);letter-spacing:.18em;color:var(--color-text-high);align-items:center;gap:.5rem;font-size:.75rem;font-weight:500;display:flex}.header-dot{color:var(--color-primary)}.header-title{letter-spacing:.2em}.app-main{flex:1;width:100%;max-width:860px;margin:0 auto;padding:2rem 1rem}.login-card{background:var(--color-surface);border:1px solid var(--color-border);text-align:center;border-radius:.75rem;max-width:420px;margin:6rem auto;padding:2.5rem 2rem;box-shadow:0 4px 24px #0000000f}.login-card h1{margin-bottom:.75rem;font-size:2rem}.login-card p{color:var(--color-muted,#9e9085);margin-bottom:2rem;font-size:.9rem}.btn-primary{background:var(--color-primary);color:#fff;font-family:var(--font-body);letter-spacing:.04em;cursor:pointer;border:none;border-radius:.375rem;padding:.75rem 1.75rem;font-size:.9rem;font-weight:500;transition:background .18s,transform .1s}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-large{width:100%;padding:1rem 2.5rem;font-size:1rem}.btn-ghost{border:1px solid var(--color-border);font-family:var(--font-body);color:var(--color-text-main);cursor:pointer;background:0 0;border-radius:.375rem;padding:.5rem 1rem;font-size:.8rem;transition:border-color .15s,background .15s}.btn-ghost:hover{background:var(--color-background);border-color:var(--color-primary)}.btn-small{padding:.375rem .75rem}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}.spinner-small{vertical-align:middle;border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;margin-right:.5rem;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.error-message{color:#c0392b;background:#fdf0ef;border:1px solid #f5c6c3;border-radius:.375rem;margin-top:1rem;padding:.75rem 1rem;font-size:.875rem}
