*,:before,:after{box-sizing:border-box}html,body{width:100%;max-width:100vw;margin:0;padding:0;overflow-x:hidden}.container{width:100%;max-width:900px;margin:0 auto;padding:0 1rem}@media (min-width:640px){.container{padding:0 2rem}}.header-inner{flex-direction:column;align-items:flex-start;gap:1rem;display:flex}@media (min-width:768px){.header-inner{flex-direction:row;justify-content:space-between;align-items:center}}.header-brand{align-items:center;gap:.75rem;display:flex}.header-title{letter-spacing:-.025em;color:#fff;margin:0;font-size:1.5rem;font-weight:700}@media (min-width:640px){.header-title{font-size:1.875rem}}.header-subtitle{color:#94a3b8;margin:.25rem 0 0;font-size:.85rem;line-height:1.4}@media (min-width:640px){.header-subtitle{font-size:.95rem}}.header-auth{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.user-email{color:#94a3b8;text-overflow:ellipsis;white-space:nowrap;max-width:150px;font-size:.8rem;overflow:hidden}@media (min-width:640px){.user-email{max-width:none;font-size:.875rem}}.main-content{padding:1.5rem 0}@media (min-width:640px){.main-content{padding:3rem 0}}.case-info-grid{grid-template-columns:1fr;gap:1rem;display:grid}@media (min-width:640px){.case-info-grid{grid-template-columns:1fr 1fr;gap:1.5rem}}.card{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:1rem;padding:1rem;box-shadow:0 1px 3px #0000000d}@media (min-width:640px){.card{padding:1.5rem}}.card-header{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}@media (min-width:640px){.card-header{flex-direction:row;justify-content:space-between;align-items:center}}.form-input{box-sizing:border-box;border:1px solid #cbd5e1;border-radius:6px;width:100%;padding:.75rem;font-size:1rem}.form-input:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{box-sizing:border-box;resize:vertical;border:1px solid #cbd5e1;border-radius:8px;width:100%;min-height:80px;padding:1rem;font-size:1rem;box-shadow:0 1px 2px #0000000d}.form-textarea:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1a}.dropzone{cursor:pointer;text-align:center;background-color:#fff;border:2px dashed #cbd5e1;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:1.5rem 1rem;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000000d}@media (min-width:640px){.dropzone{padding:2rem}}.dropzone:hover,.dropzone.active{background-color:#eff6ff;border-color:#2563eb}.file-chips{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.file-chip{color:#334155;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;align-items:center;max-width:100%;padding:.4rem .6rem;font-size:.8rem;display:flex}.file-chip-name{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}@media (min-width:640px){.file-chip-name{max-width:200px}}.submit-section{border-top:1px solid #e2e8f0;flex-direction:column;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}@media (min-width:640px){.submit-section{flex-direction:row;justify-content:flex-end;align-items:center;margin-top:3rem;padding-top:2rem}}.progress-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;width:100%;padding:1rem;box-shadow:0 1px 2px #0000000d}@media (min-width:640px){.progress-container{max-width:400px}}.btn-primary{color:#fff;cursor:pointer;background-color:#2563eb;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.75rem;width:100%;padding:1rem 2rem;font-size:1rem;font-weight:600;transition:background-color .2s,transform .1s;display:flex;box-shadow:0 4px 6px -1px #2563eb66,0 2px 4px -1px #2563eb33}@media (min-width:640px){.btn-primary{width:auto;padding:1rem 2.5rem;font-size:1.125rem}}.btn-primary:hover:not(:disabled){background-color:#1d4ed8;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;box-shadow:none;background-color:#94a3b8;transform:none}.btn-secondary{color:#475569;cursor:pointer;background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-secondary:hover{background-color:#f1f5f9}.btn-success{color:#fff;cursor:pointer;background-color:#10b981;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s}.btn-success:hover{background-color:#059669}.draft-result{margin-top:2rem}@media (min-width:640px){.draft-result{margin-top:4rem}}.draft-header{border-bottom:2px solid #e2e8f0;flex-direction:column;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}@media (min-width:640px){.draft-header{flex-direction:row;justify-content:space-between;align-items:flex-end;margin-bottom:2rem}}.draft-actions{flex-wrap:wrap;gap:.75rem;display:flex}.draft-content{background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:2rem 1rem;box-shadow:0 10px 15px -3px #0000000d,0 4px 6px -2px #00000005}@media (min-width:640px){.draft-content{padding:4rem 3rem}}.draft-text{color:#000;white-space:pre-wrap;text-align:justify;word-wrap:break-word;overflow-wrap:break-word;font-family:Times New Roman,Times,serif;font-size:1rem;line-height:1.8}@media (min-width:640px){.draft-text{font-size:1.15rem;line-height:2}}.error-message{color:#b91c1c;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;align-items:center;gap:.75rem;margin-top:1.5rem;padding:1rem;display:flex}.loading-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0f172abf;flex-direction:column;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.loading-card{text-align:center;background-color:#fff;border-radius:16px;width:400px;max-width:90%;padding:2rem;box-shadow:0 25px 50px -12px #00000040}@media (min-width:640px){.loading-card{padding:3rem 4rem}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinner{border:4px solid #e2e8f0;border-top-color:#2563eb;border-radius:50%;width:48px;height:48px;margin:0 auto 1.5rem;animation:1s linear infinite spin}@media (min-width:640px){.spinner{width:64px;height:64px}}.loading-dots:after{content:"";animation:1.5s steps(4,end) infinite dots}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.auth-screen{background-color:#0f172a;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.auth-card{text-align:center;width:100%;max-width:400px}.auth-title{color:#fff;letter-spacing:-.025em;margin:0 0 .5rem;font-size:1.75rem;font-weight:700}@media (min-width:640px){.auth-title{font-size:2rem}}.auth-subtitle{color:#94a3b8;margin:0 0 2rem;font-size:.9rem;line-height:1.5}@media (min-width:640px){.auth-subtitle{font-size:1rem}}.auth-button{color:#fff;cursor:pointer;background-color:#2563eb;border:none;border-radius:8px;align-items:center;gap:.75rem;padding:.875rem 2rem;font-size:1rem;font-weight:600;transition:all .2s;display:inline-flex;box-shadow:0 4px 6px -1px #2563eb66}.auth-button:hover{background-color:#1d4ed8}.auth-footer{color:#64748b;margin-top:1.5rem;font-size:.875rem}.form-label{color:#64748b;margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.section-label{color:#0f172a;margin-bottom:.5rem;font-size:1rem;font-weight:600;display:block}@media (min-width:640px){.section-label{font-size:1.125rem}}.help-text{color:#64748b;margin:.5rem 0 0;font-size:.8rem}@media (min-width:640px){.help-text{font-size:.875rem}}
