@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Lora:ital,wght@0,400;0,600;1,400&display=swap";:root{--bg-primary:#0f1117;--bg-secondary:#161821;--bg-tertiary:#1c1e2a;--bg-surface:#222436;--bg-hover:#2a2d42;--border-primary:#2e3148;--border-subtle:#252840;--border-accent:#63b3ed4d;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#64748b;--text-heading:#f1f5f9;--accent:#63b3ed;--accent-hover:#7cc4f5;--accent-bg:#63b3ed1a;--accent-border:#63b3ed40;--status-active:#48bb78;--status-active-bg:#48bb781f;--status-expiring:#ecc94b;--status-expiring-bg:#ecc94b1f;--status-expired:#fc8181;--status-expired-bg:#fc81811f;--status-draft:#a0aec0;--status-draft-bg:#a0aec01f;--status-pending:#d6bcfa;--status-pending-bg:#d6bcfa1f;--status-signed:#48bb78;--status-declined:#fc8181;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-serif:"Lora", Georgia, "Times New Roman", serif;--font-mono:"SF Mono", "Fira Code", monospace;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--transition:.15s ease}*,:before,:after{box-sizing:border-box}body{font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-size:15px;line-height:1.6}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--text-heading);margin:0;font-weight:600;line-height:1.3}h1{letter-spacing:-.02em;font-size:2.5rem}h2{letter-spacing:-.01em;font-size:1.75rem}h3{font-size:1.25rem}h4{font-size:1.1rem}p{margin:0}a{color:var(--accent);transition:color var(--transition);text-decoration:none}a:hover{color:var(--accent-hover)}button{font-family:var(--font-sans);cursor:pointer;border:none;outline:none}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}input,textarea{font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);transition:border-color var(--transition);padding:10px 14px;font-size:14px}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg);outline:none}input::placeholder,textarea::placeholder{color:var(--text-muted)}.serif{font-family:var(--font-serif)}.mono{font-family:var(--font-mono)}.loading{height:100vh;color:var(--text-muted);justify-content:center;align-items:center;font-size:1.1rem;display:flex}.btn{border-radius:var(--radius-md);transition:all var(--transition);white-space:nowrap;justify-content:center;align-items:center;gap:8px;font-weight:500;display:inline-flex}.btn--sm{padding:6px 16px;font-size:14px}.btn--lg{padding:14px 28px;font-size:16px}.btn--primary{background:var(--accent);color:var(--bg-primary);font-weight:600}.btn--primary:hover{background:var(--accent-hover)}.btn--primary:disabled{opacity:.5;cursor:not-allowed}.btn--secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-primary)}.btn--secondary:hover{background:var(--bg-hover);border-color:var(--accent-border)}.btn--ghost{color:var(--text-primary);border:1px solid var(--border-primary);background:0 0}.btn--ghost:hover{border-color:var(--accent-border);color:var(--accent)}.landing{min-height:100vh}.landing__nav{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);background:#0f1117d9;position:fixed;top:0;left:0;right:0}.landing__nav-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:16px 24px;display:flex}.landing__logo{color:var(--text-heading);letter-spacing:-.02em;font-size:1.4rem;font-weight:700}.landing__nav-links{align-items:center;gap:24px;display:flex}.landing__nav-links a{color:var(--text-secondary);font-size:14px;font-weight:500}.landing__nav-links a:hover{color:var(--text-primary)}.landing__hero{text-align:center;background:radial-gradient(ellipse 80% 50% at 50% -20%, #63b3ed14 0%, transparent 60%), var(--bg-primary);padding:160px 24px 100px}.landing__hero-inner{max-width:700px;margin:0 auto}.landing__hero-badge{color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:100px;margin-bottom:24px;padding:6px 16px;font-size:13px;font-weight:500;display:inline-block}.landing__headline{letter-spacing:-.03em;margin-bottom:20px;font-size:3.5rem;line-height:1.15}.landing__headline .serif{color:var(--accent);font-style:italic}.landing__subheadline{color:var(--text-secondary);max-width:560px;margin:0 auto 36px;font-size:1.15rem;line-height:1.7}.landing__ctas{flex-wrap:wrap;justify-content:center;gap:16px;display:flex}.landing__features{background:var(--bg-secondary);border-top:1px solid var(--border-subtle);border-bottom:1px solid var(--border-subtle);padding:100px 24px}.landing__features-inner{max-width:1000px;margin:0 auto}.landing__section-title{text-align:center;margin-bottom:56px;font-size:2rem}.landing__feature-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;display:grid}.feature-card{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition);padding:32px 28px}.feature-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-md);transform:translateY(-2px)}.feature-card__icon{margin-bottom:16px;font-size:2rem}.feature-card__title{margin-bottom:10px}.feature-card__desc{color:var(--text-secondary);font-size:14px;line-height:1.65}.landing__cta-section{text-align:center;background:radial-gradient(ellipse 60% 40% at 50% 120%, #63b3ed0f 0%, transparent 60%), var(--bg-primary);padding:100px 24px}.landing__cta-inner{max-width:600px;margin:0 auto}.landing__cta-inner h2{margin-bottom:12px;font-size:2rem}.landing__cta-inner p{color:var(--text-secondary);margin-bottom:32px;font-size:1.05rem}.landing__footer{border-top:1px solid var(--border-subtle);justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:24px;display:flex}.landing__footer .serif{color:var(--text-heading);font-size:1.1rem;font-weight:600}.landing__footer-copy{color:var(--text-muted);font-size:13px}.app-layout{min-height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-primary);z-index:50;flex-direction:column;width:240px;min-width:240px;padding:20px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar__logo{color:var(--text-heading);border-bottom:1px solid var(--border-primary);margin-bottom:8px;padding:0 20px 20px;font-size:1.3rem;font-weight:700;text-decoration:none;display:block}.sidebar__nav{flex-direction:column;flex:1;gap:2px;padding:8px 12px;display:flex}.sidebar__link{border-radius:var(--radius-sm);color:var(--text-secondary);text-align:left;transition:all var(--transition);background:0 0;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;display:flex}.sidebar__link:hover{background:var(--bg-hover);color:var(--text-primary)}.sidebar__link.active{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border)}.sidebar__icon{text-align:center;width:24px;font-size:1.1rem}.sidebar__footer{border-top:1px solid var(--border-primary);padding:16px 20px}.sidebar__back{color:var(--text-muted);font-size:13px}.app-main{flex:1;max-width:1200px;margin-left:240px;padding:32px 40px}.template-library__header{margin-bottom:28px}.template-library__subtitle{color:var(--text-secondary);margin-top:6px}.template-library__filters{flex-direction:column;gap:16px;margin-bottom:28px;display:flex}.template-library__search{width:100%;max-width:400px;padding:12px 16px;font-size:14px}.template-library__categories{flex-wrap:wrap;gap:8px;display:flex}.template-library__category-btn{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border-primary);transition:all var(--transition);border-radius:100px;padding:6px 16px;font-size:13px;font-weight:500}.template-library__category-btn:hover{border-color:var(--accent-border);color:var(--text-primary)}.template-library__category-btn.active{background:var(--accent-bg);color:var(--accent);border-color:var(--accent-border)}.template-library__grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;display:grid}.template-card{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);transition:all var(--transition);flex-direction:column;gap:16px;padding:24px;display:flex}.template-card:hover{border-color:var(--accent-border);box-shadow:var(--shadow-sm)}.template-card__icon{font-size:2rem}.template-card__body{flex:1}.template-card__category{text-transform:uppercase;letter-spacing:.05em;color:var(--accent);margin-bottom:6px;font-size:12px;font-weight:600;display:inline-block}.template-card__title{font-family:var(--font-serif);margin-bottom:8px;font-size:1.15rem}.template-card__desc{color:var(--text-secondary);font-size:13.5px;line-height:1.6}.template-card__meta{margin-top:12px}.template-card__clause-count{color:var(--text-muted);font-size:13px;font-weight:500}.template-card__action{border-radius:var(--radius-sm);background:var(--accent-bg);width:100%;color:var(--accent);border:1px solid var(--accent-border);transition:all var(--transition);padding:10px;font-size:14px;font-weight:600}.template-card__action:hover{background:var(--accent);color:var(--bg-primary)}.template-library__empty{text-align:center;color:var(--text-muted);grid-column:1/-1;padding:60px 20px}.clause-editor__header{margin-bottom:28px}.clause-editor__back{color:var(--text-muted);background:0 0;align-items:center;gap:6px;margin-bottom:16px;padding:0;font-size:13px;font-weight:500;display:inline-flex}.clause-editor__back:hover{color:var(--accent)}.clause-editor__title-row{align-items:baseline;gap:16px;margin-bottom:6px;display:flex}.clause-editor__clause-count{color:var(--text-muted);font-size:14px;font-weight:500}.clause-editor__subtitle{color:var(--text-secondary);font-size:14px}.clause-editor__clauses{flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.clause-block{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:all var(--transition);overflow:hidden}.clause-block:hover{border-color:var(--border-accent)}.clause-block.dragging{opacity:.5;border-color:var(--accent)}.clause-block__header{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;padding:14px 16px;display:flex}.clause-block__drag-handle{color:var(--text-muted);cursor:grab;padding:2px 4px;font-size:14px}.clause-block__number{color:var(--text-muted);min-width:20px;font-size:14px;font-weight:600}.clause-block__title-input{color:var(--text-heading);border-radius:var(--radius-sm);background:0 0;border:1px solid #0000;flex:1;padding:4px 8px;font-size:15px;font-weight:600}.clause-block__title-input:focus{border-color:var(--accent-border);background:var(--bg-surface)}.clause-block__actions{align-items:center;gap:8px;display:flex}.clause-block__remove{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;padding:2px 6px;font-size:18px;line-height:1}.clause-block__remove:hover{color:var(--status-expired);background:var(--status-expired-bg)}.clause-block__chevron{color:var(--text-muted);transition:transform var(--transition);font-size:10px}.clause-block__chevron.expanded{transform:rotate(90deg)}.clause-block__body{border-top:1px solid var(--border-subtle);padding:0 16px 16px}.clause-block__preview{color:var(--text-secondary);padding:16px 0;font-size:14.5px;line-height:1.75}.clause-variable{background:var(--accent-bg);color:var(--accent);font-family:var(--font-mono);border:1px solid var(--accent-border);border-radius:3px;padding:1px 6px;font-size:13px;font-style:normal}.clause-block__textarea{width:100%;min-height:80px;font-family:var(--font-mono);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);resize:vertical;padding:12px;font-size:13px;line-height:1.6}.clause-editor__add{border-radius:var(--radius-md);background:var(--bg-surface);color:var(--accent);border:1px dashed var(--accent-border);transition:all var(--transition);width:100%;padding:12px 24px;font-size:14px;font-weight:600}.clause-editor__add:hover{background:var(--accent-bg);border-style:solid}.signature-flow__header{margin-bottom:28px}.signature-flow__subtitle{color:var(--text-secondary);margin-top:6px}.signature-flow__section{margin-bottom:32px}.signature-flow__section h3{color:var(--text-heading);margin-bottom:16px}.signature-flow__signers{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.signer-row{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:all var(--transition);align-items:center;gap:14px;padding:14px 16px;display:flex}.signer-row:hover{border-color:var(--border-accent)}.signer-row__status-icon{border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;display:flex}.signer-row__status-icon--pending{background:var(--status-pending-bg);color:var(--status-pending)}.signer-row__status-icon--signed{background:var(--status-active-bg);color:var(--status-signed)}.signer-row__status-icon--declined{background:var(--status-expired-bg);color:var(--status-declined)}.signer-row__info{flex-direction:column;flex:1;gap:2px;display:flex}.signer-row__name{color:var(--text-heading);font-size:14px;font-weight:600}.signer-row__email{color:var(--text-muted);font-size:13px}.signer-row__badge{text-transform:uppercase;letter-spacing:.05em;border-radius:100px;padding:4px 10px;font-size:12px;font-weight:600}.signer-row__badge--pending{background:var(--status-pending-bg);color:var(--status-pending)}.signer-row__badge--signed{background:var(--status-active-bg);color:var(--status-signed)}.signer-row__badge--declined{background:var(--status-expired-bg);color:var(--status-declined)}.signer-row__date{color:var(--text-muted);font-size:13px}.signer-row__remove{color:var(--text-muted);border-radius:var(--radius-sm);background:0 0;padding:2px 8px;font-size:18px}.signer-row__remove:hover{color:var(--status-expired)}.signature-flow__add-signer{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.signature-flow__add-signer input{flex:1;min-width:180px}.signature-pad{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);overflow:hidden}.signature-pad__canvas{background:var(--bg-secondary);cursor:crosshair;width:100%;height:200px;display:block}.signature-pad__actions{border-top:1px solid var(--border-primary);gap:12px;padding:12px 16px;display:flex}.signature-flow__actions{border-top:1px solid var(--border-primary);padding-top:20px}.expiration-dash__header{margin-bottom:28px}.expiration-dash__subtitle{color:var(--text-secondary);margin-top:6px}.expiration-dash__stats{flex-wrap:wrap;gap:12px;margin-bottom:28px;display:flex}.stat-card{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);min-width:100px;transition:all var(--transition);cursor:pointer;flex-direction:column;flex:1;align-items:center;gap:4px;padding:16px 20px;display:flex}.stat-card:hover{border-color:var(--border-accent)}.stat-card--active{border-color:var(--accent);background:var(--accent-bg)}.stat-card__count{color:var(--text-heading);font-size:1.5rem;font-weight:700}.stat-card__label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:500}.expiration-dash__table-wrap{overflow-x:auto}.expiration-table{border-collapse:collapse;width:100%;font-size:14px}.expiration-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border-primary);background:var(--bg-secondary);padding:12px 16px;font-size:12px;font-weight:600}.expiration-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.expiration-table th.sortable:hover{color:var(--accent)}.expiration-table td{border-bottom:1px solid var(--border-subtle);vertical-align:middle;padding:14px 16px}.expiration-table__row:hover td{background:var(--bg-tertiary)}.expiration-table__title{color:var(--text-heading);font-weight:600}.expiration-table__parties{color:var(--text-secondary);font-size:13px}.expiration-table__date{font-family:var(--font-mono);color:var(--text-secondary);font-size:13px}.expiration-table__days{font-size:13px;font-weight:600}.expiration-table__days.overdue{color:var(--status-expired)}.expiration-table__value{color:var(--text-secondary);font-size:13px}.status-badge{white-space:nowrap;border-radius:100px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-block}.status-badge--active{background:var(--status-active-bg);color:var(--status-active)}.status-badge--expiring-soon{background:var(--status-expiring-bg);color:var(--status-expiring)}.status-badge--expired{background:var(--status-expired-bg);color:var(--status-expired)}.status-badge--draft{background:var(--status-draft-bg);color:var(--status-draft)}.status-badge--pending-signature{background:var(--status-pending-bg);color:var(--status-pending)}.expiration-table__row--expiring-soon .expiration-table__days{color:var(--status-expiring)}.expiration-table__row--active .expiration-table__days{color:var(--status-active)}.expiration-table__row--expired .expiration-table__days{color:var(--status-expired)}.expiration-dash__empty{text-align:center;color:var(--text-muted);padding:48px 20px}.audit-trail__header{margin-bottom:24px}.audit-trail__subtitle{color:var(--text-secondary);margin-top:6px}.audit-trail__contract-label{align-items:center;gap:16px;margin-bottom:28px;display:flex}.audit-trail__contract-badge{font-family:var(--font-serif);color:var(--text-heading);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:6px 16px;font-size:1.1rem;font-weight:600}.audit-trail__event-count{color:var(--text-muted);font-size:13px}.audit-trail__timeline{flex-direction:column;gap:32px;display:flex}.audit-trail__date-marker{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);margin-bottom:16px;padding:8px 16px;font-size:13px;font-weight:600;display:inline-block}.audit-trail__events{flex-direction:column;gap:0;padding-left:20px;display:flex}.audit-event{padding:0 0 20px 28px;position:relative}.audit-event__line{background:var(--border-primary);width:1px;position:absolute;top:12px;bottom:0;left:5px}.audit-event:last-child .audit-event__line{display:none}.audit-event__dot{background:var(--accent);border:2px solid var(--bg-primary);border-radius:50%;width:11px;height:11px;position:absolute;top:8px;left:0}.audit-event__content{background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);transition:border-color var(--transition);padding:14px 16px}.audit-event__content:hover{border-color:var(--border-accent)}.audit-event__top{align-items:center;gap:10px;margin-bottom:4px;display:flex}.audit-event__icon{font-size:1rem}.audit-event__action{color:var(--text-heading);flex:1;font-size:14px;font-weight:600}.audit-event__time{color:var(--text-muted);font-size:12px;font-family:var(--font-mono)}.audit-event__actor{color:var(--accent);margin-bottom:4px;font-size:13px;font-weight:500}.audit-event__details{color:var(--text-secondary);font-size:13px;line-height:1.5}@media (width<=768px){.landing__headline{font-size:2.2rem}.sidebar{width:60px;min-width:60px}.sidebar__label,.sidebar__logo,.sidebar__back{display:none}.sidebar__nav{padding:8px 6px}.sidebar__link{justify-content:center;padding:10px}.app-main{margin-left:60px;padding:20px 16px}.template-library__grid{grid-template-columns:1fr}.expiration-dash__stats{grid-template-columns:repeat(3,1fr);display:grid}.signature-flow__add-signer{flex-direction:column}.signature-flow__add-signer input{width:100%}}
