: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:#4a7c59;--color-success-soft:#eff5f1;--color-blue:#4a6fa5;--color-blue-soft:#eef2f8;--color-amber:#c8883a;--color-amber-soft:#faf3e8;--color-purple:#7b6fa5;--color-purple-soft:#f2f0f8;--color-destructive:#b0392b;--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{margin-bottom:1rem}.form-header-top{justify-content:space-between;align-items:baseline;display:flex}.form-header h1{margin:0;font-size:2.25rem}.form-scan-row{align-items:center;gap:.75rem;margin-bottom:1.25rem;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}.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}.transfer-panels{border:1px solid var(--color-border);border-radius:.5rem;grid-template-columns:1fr 1fr;margin-bottom:1rem;display:grid;overflow:hidden}.panel-selected{border-right:1px solid var(--color-border)}.panel-header{border-bottom:1px solid var(--color-border);background:#f7f4ef;justify-content:space-between;align-items:center;height:48px;padding:0 1rem;display:flex}.panel-header-left{align-items:center;gap:.5rem;display:flex}.panel-name{text-transform:uppercase;letter-spacing:.07em;color:var(--color-muted,#9e9085);font-size:.72rem;font-weight:600}.count-badge{background:var(--color-primary);color:#fff;text-align:center;border-radius:999px;min-width:24px;padding:.15rem .5rem;font-size:.65rem;font-weight:700}.count-zero{color:var(--color-muted,#9e9085);border:1px solid var(--color-border);background:#f7f4ef}.clear-btn{color:var(--color-muted,#9e9085);cursor:pointer;text-underline-offset:2px;background:0 0;border:none;font-size:.7rem;text-decoration:underline}.lib-edit-btn{color:var(--color-muted,#9e9085);border:1px solid var(--color-border);cursor:pointer;white-space:nowrap;background:#f7f4ef;border-radius:.375rem;padding:.25rem .6rem;font-family:inherit;font-size:.72rem;transition:border-color .15s,color .15s,background .15s}.lib-edit-btn.active{border-color:var(--color-primary);color:var(--color-primary);background:#b89b7214}.empty-msg-mobile{display:none}.empty-msg-desktop{display:block}.area-list{min-height:260px;max-height:460px;list-style:none;overflow-y:auto}.area-item{border-bottom:1px solid #ede8e0;align-items:stretch;font-size:.85rem;display:flex}.area-item:last-child{border-bottom:none}.area-item-label{color:var(--color-text-main);flex:1;align-self:center;padding:.6rem 0 .6rem 1rem}.item-controls{border-left:1px solid #ede8e0;align-items:stretch;display:flex}.ctrl-btn{cursor:pointer;color:var(--color-border);background:0 0;border:none;border-left:1px solid #ede8e0;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:0 .55rem;font-size:.9rem;transition:color .12s,background .12s;display:flex}.ctrl-btn:first-child{border-left:none}.ctrl-btn:hover:not(:disabled){color:var(--color-primary);background:#f7f4ef}.ctrl-btn:disabled{opacity:.2;cursor:default}.ctrl-btn.remove:hover{color:var(--color-destructive,#b0392b);background:#fdf5ec}.library-item{border-bottom:1px solid #ede8e0;align-items:stretch;font-size:.85rem;transition:background .12s;display:flex}.library-item:last-child{border-bottom:none}.library-item-label{color:var(--color-text-main);flex:1;align-self:center;padding:.6rem 1rem}.library-item.normal{cursor:pointer}.library-item.normal:hover{background:#f7f4ef}.library-item.normal:hover .add-icon{color:var(--color-primary)}.library-item.editing .library-item-label{cursor:default;color:var(--color-muted,#9e9085)}.add-icon{color:var(--color-border);align-self:center;padding:0 .75rem;font-size:.85rem}.empty-state{min-height:260px;color:var(--color-border);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:1.5rem;font-size:.82rem;line-height:1.6;display:flex}.empty-icon{opacity:.4;font-size:1.5rem}.library-footer{border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;padding:.75rem 1rem;display:flex}.lib-add-row{gap:.5rem;display:flex}.lib-input{border:1px solid var(--color-border);color:var(--color-text-main);background:#fff;border-radius:.375rem;flex:1;padding:.45rem .75rem;font-family:inherit;font-size:.8rem}.lib-btn{border:1px solid var(--color-border);color:var(--color-text-main);cursor:pointer;white-space:nowrap;background:#fff;border-radius:.375rem;padding:.45rem .75rem;font-family:inherit;font-size:.78rem}.lib-footer-row{justify-content:space-between;align-items:center;display:flex}.lib-reset{color:var(--color-muted,#9e9085);cursor:pointer;text-align:left;text-underline-offset:2px;background:0 0;border:none;font-size:.72rem;text-decoration:underline}.lib-done-btn{border:1px solid var(--color-primary);color:var(--color-primary);cursor:pointer;background:#b89b7214;border-radius:.375rem;padding:.3rem .75rem;font-family:inherit;font-size:.72rem}.add-area-row.dimmed,.hint-text.dimmed{opacity:.4;pointer-events:none}.hint-text{color:var(--color-muted,#9e9085);margin-top:.4rem;font-size:.75rem;font-style:italic}.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}.scan-btn-wrap{flex-direction:column;align-items:flex-start;display:flex;position:relative}.scan-confirm-btns{gap:.5rem;display:flex}.scan-pending-name{color:var(--color-muted,#9e9085);text-overflow:ellipsis;white-space:nowrap;max-width:240px;font-size:.7rem;overflow:hidden}.scan-error{color:var(--color-destructive,#b0392b);white-space:nowrap;pointer-events:none;font-size:.72rem;position:absolute;top:calc(100% + 4px);left:0}.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}.transfer-panels{grid-template-columns:1fr}.panel-selected{border-right:none;border-bottom:1px solid var(--color-border)}.empty-msg-desktop{display:none}.empty-msg-mobile{display:block}}@media (prefers-reduced-motion:reduce){.sync-dot{animation:none}}.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:100dvh;animation:.25s slideInRight;display:flex;position:fixed;top:0;right:0;overflow:hidden;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;overflow-y:auto}.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;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:.25rem;font-size:1.5rem;line-height:1;transition:color .15s;display:flex}.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);flex-shrink:0;align-items:center;gap:.75rem;padding:1.5rem 2rem;display:flex}.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:100dvw}.panel-field-row{flex-direction:column}}@media (width<=640px){.properties-table-section{padding:1rem}.properties-table thead{display:none}.properties-table,.properties-table tbody,.properties-table tr,.properties-table td{width:100%;display:block}.properties-table tbody tr.clickable-row{border:1px solid var(--color-border);background:var(--color-surface);border-radius:.5rem;margin-bottom:.75rem;padding:.75rem}.properties-table td{border-bottom:none;padding:.3rem 0;font-size:.85rem}.properties-table td:before{content:attr(data-label);text-transform:uppercase;letter-spacing:.05em;color:var(--color-muted);margin-bottom:.15rem;font-size:.68rem;font-weight:600;display:block}.properties-table td:empty{display:none}}@media (prefers-reduced-motion:reduce){.properties-view,.panel-overlay,.edit-panel{animation:none}}.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%)}@media (width<=640px){.header-nav{order:3;justify-content:center;gap:1.5rem;width:100%;position:static;transform:none}}.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:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:2px}.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}.app-main.wide{max-width:1160px}.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}@media (prefers-reduced-motion:reduce){.spinner,.spinner-small{border-top-color:var(--color-primary);animation:none}.sync-dot,.panel-overlay{animation:none}}
