@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Source+Sans+3:wght@400;500;600&display=swap";:root{--font-heading:"Outfit", system-ui, sans-serif;--font-body:"Source Sans 3", system-ui, sans-serif;--color-bg:#f7faf7;--color-surface:#fff;--color-surface-elevated:#f0f5f0;--color-surface-glass:#ffffffd9;--color-border:#d4e4d4;--color-border-light:#e8f0e8;--color-text:#1a2e1a;--color-text-secondary:#3d5a3d;--color-text-muted:#7a9a7a;--color-green-deep:#1a3a2a;--color-green:#2d6a4f;--color-green-mid:#40916c;--color-green-bright:#52b788;--color-green-light:#b7e4c7;--color-green-soft:#2d6a4f14;--color-primary:#2d6a4f;--color-primary-hover:#1a3a2a;--color-primary-soft:#2d6a4f1a;--color-success:#2d6a4f;--color-warning:#c77b1f;--color-danger:#c0392b;--color-gold:#c9a84c;--color-cream:#fdfcf7;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #1a3a2a0f;--shadow-md:0 4px 16px #1a3a2a14;--shadow-lg:0 8px 32px #1a3a2a1a;--shadow-xl:0 16px 48px #1a3a2a1f;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-smooth:.4s cubic-bezier(.16, 1, .3, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);min-height:100dvh;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--color-green-deep);font-weight:700;line-height:1.2}a{color:var(--color-primary);text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}input,textarea,select{font-family:var(--font-body)}body:before{content:"";pointer-events:none;z-index:-1;background:radial-gradient(circle at 20% 80%,#2d6a4f08 0%,#0000 50%),radial-gradient(circle at 80% 20%,#2d6a4f05 0%,#0000 50%);position:fixed;inset:0}.login-page{background:var(--color-green-deep);grid-template-columns:1fr;min-height:100dvh;display:grid}.login-hero{display:none;position:relative;overflow:hidden}.login-hero-img{object-fit:cover;width:100%;height:100%}.login-hero-overlay{background:linear-gradient(135deg,#1a3a2a66,#1a3a2a33);position:absolute;inset:0}.login-content{padding:var(--space-xl);background:linear-gradient(160deg, var(--color-bg) 0%, #eaf5ea 50%, var(--color-bg) 100%);justify-content:center;align-items:center;display:flex}.login-card{align-items:center;gap:var(--space-lg);flex-direction:column;width:100%;max-width:360px;display:flex}.login-logo{border-radius:var(--radius-xl);width:140px;height:140px;box-shadow:var(--shadow-xl);border:3px solid var(--color-surface);overflow:hidden}.login-logo img{object-fit:cover;width:100%;height:100%}.login-text{text-align:center}.login-text h1{letter-spacing:-.03em;color:var(--color-green-deep);font-size:1.75rem;font-weight:800}.login-text p{color:var(--color-text-muted);margin-top:2px;font-size:.9375rem}.login-error{width:100%;color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);text-align:center;background:#c0392b14;font-size:.8125rem}.login-google{justify-content:center;align-items:center;gap:var(--space-sm);width:100%;padding:14px var(--space-lg);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:.9375rem;font-weight:600;font-family:var(--font-heading);min-height:52px;box-shadow:var(--shadow-sm);transition:all var(--transition-smooth);display:flex}.login-google:hover:not(:disabled){border-color:var(--color-green);box-shadow:var(--shadow-md);transform:translateY(-1px)}.login-google:active:not(:disabled){transform:translateY(0)}.login-google:disabled{opacity:.6}.login-footer{margin-top:var(--space-md)}.login-footer span{color:var(--color-text-muted);letter-spacing:.05em;text-transform:uppercase;font-size:.6875rem;font-weight:500}@media (width>=768px){.login-page{grid-template-columns:1fr 1fr}.login-hero{display:block}.login-logo{width:160px;height:160px}.login-text h1{font-size:2rem}}.topbar{padding:var(--space-sm) var(--space-lg);background:var(--color-surface);border-bottom:1px solid var(--color-border-light);z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-brand{align-items:center;gap:var(--space-sm);display:flex}.topbar-logo{border-radius:var(--radius-sm);object-fit:cover;width:36px;height:36px}.topbar-name{font-family:var(--font-heading);color:var(--color-green-deep);letter-spacing:-.02em;font-size:.9375rem;font-weight:700}.topbar-logout{color:var(--color-text-muted);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;font-size:.8125rem}.topbar-logout:hover{color:var(--color-danger)}.upload-main{padding:var(--space-xl) var(--space-md);max-width:520px;margin:0 auto}.upload-container{gap:var(--space-xl);flex-direction:column;display:flex}.upload-intro h1{letter-spacing:-.03em;font-size:1.5rem;font-weight:800}.upload-intro p{color:var(--color-text-muted);margin-top:4px;font-size:.9375rem}.progress-track{gap:var(--space-xs);flex-direction:column;display:flex}.progress-bar{background:var(--color-surface-elevated);border-radius:var(--radius-full);height:6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--color-green), var(--color-green-bright));border-radius:var(--radius-full);height:100%;transition:width .5s cubic-bezier(.16,1,.3,1)}.progress-text{color:var(--color-text-muted);font-size:.75rem;font-weight:500}.checklist{background:var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:2px;display:flex;overflow:hidden}.checklist-item{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-surface);animation:.4s both fadeSlideIn;display:flex}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.checklist-icon{border-radius:var(--radius-md);background:var(--color-surface-elevated);width:40px;height:40px;transition:all var(--transition-smooth);flex-shrink:0;justify-content:center;align-items:center;display:flex}.checklist-icon svg{width:20px;height:20px;color:var(--color-text-muted)}.icon-done{background:var(--color-green)}.icon-done svg{color:#fff;width:18px;height:18px}.checklist-body{flex-direction:column;gap:1px;min-width:0;display:flex}.checklist-label{color:var(--color-text-secondary);transition:color var(--transition-fast);font-size:.875rem;font-weight:500}.item-done .checklist-label{color:var(--color-text)}.checklist-detail{color:var(--color-green-mid);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;font-weight:500;overflow:hidden}.checklist-delete{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition-fast);opacity:0;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;display:flex}.checklist-item:hover .checklist-delete{opacity:1}.checklist-delete svg{width:15px;height:15px}.checklist-delete:hover{color:var(--color-danger);background:#c0392b14}@media (width<=640px){.checklist-delete{opacity:1}}.upload-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);cursor:pointer;min-height:120px;transition:all var(--transition-smooth);background:var(--color-surface);justify-content:center;align-items:center;display:flex}.upload-zone:hover{border-color:var(--color-green);background:var(--color-green-soft);box-shadow:var(--shadow-md);transform:translateY(-2px)}.upload-zone:active{transform:translateY(0)}.zone-loading{border-color:var(--color-green-light);background:var(--color-green-soft);pointer-events:none}.upload-zone input{display:none}.upload-cta{align-items:center;gap:var(--space-sm);padding:var(--space-xl);flex-direction:column;display:flex}.upload-icon{background:var(--color-green-soft);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.upload-icon svg{width:24px;height:24px;color:var(--color-green)}.upload-cta-text{font-family:var(--font-heading);color:var(--color-green-deep);font-size:.9375rem;font-weight:600}.upload-cta-hint{color:var(--color-text-muted);font-size:.75rem}.upload-loading{align-items:center;gap:var(--space-sm);padding:var(--space-xl);color:var(--color-green);font-size:.875rem;font-weight:500;display:flex}.spinner{border:2.5px solid var(--color-green-light);border-top-color:var(--color-green);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.upload-done{text-align:center;padding:var(--space-2xl) var(--space-lg);background:var(--color-green-soft);border:1.5px solid var(--color-green-light);border-radius:var(--radius-lg)}.done-icon{background:var(--color-green);width:56px;height:56px;margin:0 auto var(--space-md);border-radius:50%;justify-content:center;align-items:center;display:flex}.done-icon svg{color:#fff;width:28px;height:28px}.upload-done h3{color:var(--color-green-deep);font-size:1.125rem}.upload-done p{color:var(--color-green-mid);margin-top:4px;font-size:.875rem}.upload-error{color:var(--color-danger);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:#c0392b0f;border:1px solid #c0392b26;font-size:.8125rem}.otros-section{background:var(--color-surface);border:1.5px solid var(--color-warning);border-radius:var(--radius-lg);overflow:hidden}.otros-header{align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:#c77b1f0f;display:flex}.otros-icon{border-radius:var(--radius-md);background:#c77b1f1f;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.otros-icon svg{width:18px;height:18px;color:var(--color-warning)}.otros-header h3{color:var(--color-warning);font-size:.875rem;font-weight:700}.otros-header p{color:var(--color-text-muted);font-size:.6875rem}.otros-list{flex-direction:column;display:flex}.otros-item{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);border-top:1px solid var(--color-border-light);display:flex}.otros-info{flex-direction:column;gap:1px;min-width:0;display:flex}.otros-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:.8125rem;font-weight:500;overflow:hidden}.otros-desc{color:var(--color-text-muted);font-size:.6875rem}.otros-delete{border-radius:var(--radius-sm);width:32px;height:32px;color:var(--color-text-muted);transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.otros-delete svg{width:16px;height:16px}.otros-delete:hover{color:var(--color-danger);background:#c0392b14}.toast{align-items:center;gap:var(--space-sm);background:var(--color-green-deep);color:#fff;padding:var(--space-sm) var(--space-lg) var(--space-sm) var(--space-sm);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:1000;max-width:calc(100vw - 48px);animation:.4s cubic-bezier(.16,1,.3,1) toastIn;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(16px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.toast-icon{border-radius:var(--radius-sm);background:#ffffff26;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.toast-icon svg{width:16px;height:16px}.toast-body{flex-direction:column;display:flex}.toast-title{font-size:.8125rem;font-weight:600;font-family:var(--font-heading)}.toast-detail{opacity:.75;font-size:.6875rem}
