*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green:#2d6a4f;--green-light:#40916c;--green-pale:#d8f3dc;--navy:#1a2440;--cream:#fafaf8;--text:#1a1a1a;--muted:#6b7280;--border:#e5e7eb;--error:#dc2626;--white:#fff;--shadow:0 1px 3px #00000014,0 4px 16px #0000000f;--shadow-lg:0 4px 6px #0000000d,0 10px 40px #0000001a}body{background:var(--cream);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:DM Sans,sans-serif}nav{background:var(--white);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;height:60px;padding:0 2rem;display:flex;position:sticky;top:0}.nav-brand{color:var(--green);letter-spacing:-.02em;cursor:pointer;font-family:Playfair Display,serif;font-size:1.3rem;font-weight:700;text-decoration:none}.nav-actions{align-items:center;gap:.75rem;display:flex}.nav-user{color:var(--muted);font-size:.85rem}.btn{cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;gap:.5rem;padding:.6rem 1.25rem;font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-light);transform:translateY(-1px);box-shadow:0 4px 12px #2d6a4f4d}.btn-primary:active{transform:translateY(0)}.btn-outline{color:var(--green);border:1.5px solid var(--green);background:0 0}.btn-outline:hover{background:var(--green-pale)}.btn-ghost{color:var(--muted);background:0 0;padding:.5rem .75rem}.btn-ghost:hover{color:var(--text);background:var(--border)}.btn-lg{border-radius:8px;padding:.85rem 2rem;font-size:1rem}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.field{flex-direction:column;gap:.4rem;display:flex}.field label{color:var(--text);font-size:.85rem;font-weight:500}.field input,.field textarea,.field select{border:1.5px solid var(--border);color:var(--text);background:#fff;border-radius:6px;width:100%;padding:.7rem .9rem;font-family:DM Sans,sans-serif;font-size:.95rem;transition:border-color .15s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--green);outline:none;box-shadow:0 0 0 3px #2d6a4f1a}.field textarea{resize:vertical;min-height:120px;line-height:1.5}.field-error{color:var(--error);font-size:.8rem}.field-hint{color:var(--muted);font-size:.8rem}.card{box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;border-radius:12px;padding:2rem}.container{max-width:680px;margin:0 auto;padding:2rem 1.5rem}.container-wide{max-width:900px;margin:0 auto;padding:2rem 1.5rem}.auth-wrap{background:linear-gradient(135deg,#f0fdf4 0%,#fafaf8 50%,#f0f4ff 100%);justify-content:center;align-items:center;min-height:calc(100vh - 60px);padding:2rem 1.5rem;display:flex}.auth-card{width:100%;max-width:420px;box-shadow:var(--shadow-lg);border:1px solid var(--border);background:#fff;border-radius:16px;padding:2.5rem}.auth-logo{background:var(--navy);color:#fff;letter-spacing:-.02em;border-radius:12px;justify-content:center;align-items:center;width:52px;height:52px;margin-bottom:1.5rem;font-family:Playfair Display,serif;font-size:1.1rem;font-weight:700;display:flex}.auth-title{color:var(--navy);margin-bottom:.4rem;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700}.auth-sub{color:var(--muted);margin-bottom:2rem;font-size:.9rem;line-height:1.5}.auth-switch{text-align:center;color:var(--muted);margin-top:1.5rem;font-size:.85rem}.auth-switch button{color:var(--green);cursor:pointer;font-family:inherit;font-weight:500;font-size:inherit;background:0 0;border:none}.auth-switch button:hover{text-decoration:underline}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-divider{align-items:center;gap:1rem;margin:.5rem 0;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-divider span{color:var(--muted);white-space:nowrap;font-size:.8rem}.hero{text-align:center;max-width:620px;margin:0 auto;padding:4rem 1.5rem 3rem}.hero-badge{background:var(--green-pale);color:var(--green);border-radius:100px;align-items:center;gap:.4rem;margin-bottom:1.5rem;padding:.3rem .9rem;font-size:.8rem;font-weight:500;display:inline-flex}.hero h1{color:var(--navy);letter-spacing:-.02em;margin-bottom:1rem;font-family:Playfair Display,serif;font-size:clamp(2rem,5vw,3rem);font-weight:700;line-height:1.2}.hero h1 em{color:var(--green);font-style:italic}.hero p{color:var(--muted);margin-bottom:2rem;font-size:1.05rem;line-height:1.6}.hero-cta{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.hero-trust{color:var(--muted);margin-top:1.5rem;font-size:.8rem}.wizard-wrap{padding:2rem 0}.wizard-progress{justify-content:center;align-items:center;gap:0;margin-bottom:2.5rem;display:flex}.wizard-step-dot{flex-direction:column;align-items:center;gap:.4rem;display:flex}.wizard-step-dot .dot{border:2px solid var(--border);width:32px;height:32px;color:var(--muted);z-index:1;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:600;transition:all .2s;display:flex;position:relative}.wizard-step-dot.active .dot{border-color:var(--green);background:var(--green);color:#fff;box-shadow:0 0 0 4px #2d6a4f26}.wizard-step-dot.done .dot{border-color:var(--green);background:var(--green-pale);color:var(--green)}.wizard-step-dot .label{color:var(--muted);white-space:nowrap;font-size:.7rem;font-weight:500}.wizard-step-dot.active .label{color:var(--green)}.wizard-connector{background:var(--border);width:60px;height:2px;margin:0 0 1.4rem;transition:background .2s}.wizard-connector.done{background:var(--green)}.step-card{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:16px;padding:2rem;animation:.25s fadeUp}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.step-header{margin-bottom:1.75rem}.step-header h2{color:var(--navy);margin-bottom:.35rem;font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700}.step-header p{color:var(--muted);font-size:.9rem;line-height:1.5}.step-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:1.75rem;padding-top:1.5rem;display:flex}.approach-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.approach-option{border:2px solid var(--border);cursor:pointer;text-align:left;background:#fff;border-radius:10px;padding:1rem;transition:all .15s}.approach-option:hover{border-color:var(--green-light);background:#f9fdfb}.approach-option.selected{border-color:var(--green);background:var(--green-pale)}.approach-icon{margin-bottom:.4rem;font-size:1.4rem}.approach-label{color:var(--navy);font-size:.9rem;font-weight:600}.approach-desc{color:var(--muted);margin-top:.2rem;font-size:.78rem;line-height:1.4}.state-grid{border:1.5px solid var(--border);border-radius:8px;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:.5rem;max-height:240px;padding:.25rem;display:grid;overflow-y:auto}.state-grid::-webkit-scrollbar{width:6px}.state-grid::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.state-btn{border:1.5px solid var(--border);cursor:pointer;text-align:center;color:var(--text);background:#fff;border-radius:6px;padding:.5rem .25rem;font-family:DM Sans,sans-serif;font-size:.75rem;font-weight:500;transition:all .1s}.state-btn:hover{border-color:var(--green-light);color:var(--green)}.state-btn.selected{border-color:var(--green);background:var(--green-pale);color:var(--green);font-weight:600}.upload-zone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:#fafafa;border-radius:10px;padding:1.5rem;transition:all .15s}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--green);background:var(--green-pale)}.upload-zone-icon{margin-bottom:.5rem;font-size:2rem}.upload-zone p{color:var(--muted);font-size:.85rem}.upload-zone strong{color:var(--green)}.upload-preview{background:var(--green-pale);border:1px solid #2d6a4f33;border-radius:8px;align-items:center;gap:.75rem;margin-top:.75rem;padding:.75rem;display:flex}.upload-preview span{color:var(--green);flex:1;font-size:.85rem;font-weight:500}.upload-preview button{cursor:pointer;color:var(--muted);background:0 0;border:none;font-size:1.1rem}.generating-wrap{text-align:center;padding:3rem 1.5rem}.spinner{border:3px solid var(--green-pale);border-top-color:var(--green);border-radius:50%;width:48px;height:48px;margin:0 auto 1.5rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.generating-steps{flex-direction:column;gap:.6rem;margin-top:1.5rem;list-style:none;display:flex}.generating-steps li{color:var(--muted);align-items:center;gap:.5rem;font-size:.85rem;display:flex}.gen-dot{background:var(--green-pale);border-radius:50%;flex-shrink:0;width:8px;height:8px}.gen-dot.active{background:var(--green);animation:1s infinite pulse}.gen-dot.done{background:var(--green)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.output-wrap{padding:2rem 0}.output-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.5rem;display:flex}.output-title{color:var(--navy);font-family:Playfair Display,serif;font-size:1.3rem;font-weight:700}.output-actions{gap:.5rem;display:flex}.letter-container{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:12px;overflow:hidden}.letter-paper{color:#1a1a1a;white-space:pre-wrap;min-height:600px;padding:3rem;font-family:"Source Serif 4",Georgia,serif;font-size:12pt;line-height:1.7}.letter-paper p{margin-bottom:1em}.rights-section{border-top:1px solid var(--border);background:#f8fffe;border-bottom-right-radius:12px;border-bottom-left-radius:12px;padding:1.5rem 3rem}.rights-title{text-transform:uppercase;letter-spacing:.08em;color:var(--green);margin-bottom:.75rem;font-size:.75rem;font-weight:600}.rights-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.rights-list li{color:var(--muted);align-items:flex-start;gap:.5rem;font-size:.82rem;line-height:1.4;display:flex}.rights-list li:before{content:"§";color:var(--green);flex-shrink:0;margin-top:.05em;font-weight:600}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#00000080;justify-content:center;align-items:center;padding:1.5rem;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:440px;padding:2.5rem;animation:.25s slideUp;box-shadow:0 20px 60px #0003}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-icon{margin-bottom:1rem;font-size:2.5rem}.modal-title{color:var(--navy);margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700}.modal-sub{color:var(--muted);margin-bottom:1.5rem;font-size:.9rem;line-height:1.5}.modal-price{color:var(--green);margin-bottom:.2rem;font-family:Playfair Display,serif;font-size:2rem;font-weight:700}.modal-price-label{color:var(--muted);margin-bottom:1.5rem;font-size:.8rem}.modal-features{text-align:left;flex-direction:column;gap:.5rem;margin-bottom:1.75rem;list-style:none;display:flex}.modal-features li{align-items:center;gap:.6rem;font-size:.88rem;display:flex}.modal-features li .check{color:var(--green);flex-shrink:0;font-weight:700}.modal-trust{color:var(--muted);margin-top:.75rem;font-size:.75rem}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:var(--navy);margin-bottom:.3rem;font-family:Playfair Display,serif;font-size:1.7rem;font-weight:700}.dashboard-header p{color:var(--muted);font-size:.9rem}.letters-grid{flex-direction:column;gap:.75rem;display:flex}.letter-item{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:10px;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;transition:all .15s;display:flex}.letter-item:hover{border-color:var(--green-light);box-shadow:var(--shadow)}.letter-item-info{flex:1;min-width:0}.letter-item-title{white-space:nowrap;text-overflow:ellipsis;margin-bottom:.2rem;font-size:.9rem;font-weight:600;overflow:hidden}.letter-item-meta{color:var(--muted);font-size:.78rem}.letter-item-badge{white-space:nowrap;border-radius:100px;flex-shrink:0;padding:.2rem .6rem;font-size:.72rem;font-weight:500}.badge-dispute{color:#92400e;background:#fef3c7}.badge-extension{color:#1e40af;background:#dbeafe}.badge-comply{color:#166534;background:#dcfce7}.badge-clarification{color:#6b21a8;background:#f3e8ff}.loading-dots{align-items:center;gap:4px;display:inline-flex}.loading-dots span{opacity:.3;background:currentColor;border-radius:50%;width:6px;height:6px;animation:1.2s infinite blink}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,to{opacity:.3}50%{opacity:1}}.notif{background:var(--navy);color:#fff;z-index:300;box-shadow:var(--shadow-lg);border-radius:10px;max-width:320px;padding:.85rem 1.25rem;font-size:.875rem;animation:.25s slideInRight;position:fixed;bottom:1.5rem;right:1.5rem}.notif.success{background:var(--green)}.notif.error{background:var(--error)}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translateY(0)}}.divider{background:var(--border);height:1px;margin:1.5rem 0}.text-sm{font-size:.85rem}.text-muted{color:var(--muted)}.text-center{text-align:center}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mt-2{margin-top:1rem}.flex{display:flex}.gap-2{gap:.75rem}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.justify-between{justify-content:space-between}.w-full{width:100%}@media (max-width:600px){.approach-grid{grid-template-columns:1fr}.letter-paper{padding:1.5rem}.rights-section{padding:1rem 1.5rem}.wizard-connector{width:30px}.auth-card{padding:1.75rem}.modal-card{padding:2rem 1.5rem}}
