:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;margin:0 auto;text-align:center}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}input{font-family:inherit;font-size:1em;padding:.6em;border-radius:8px;border:1px solid #444;background-color:#1a1a1a;color:#ffffffde}input:focus{outline:none;border-color:#646cff}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}button{background-color:#f9f9f9}input{background-color:#f9f9f9;border-color:#ccc;color:#213547}}.app{min-height:100vh;padding:1rem}.app-header{margin-bottom:1.75rem}.app-header h1{font-size:2.5rem;margin-bottom:.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.app-header p{font-size:1.1rem;opacity:.8}.app-main{max-width:720px;margin:0 auto;display:flex;flex-direction:column;gap:1.25rem;padding:0 .5rem}.file-uploader{width:100%}.drop-zone{border:2px dashed #666;border-radius:12px;padding:1.5rem 1.25rem;text-align:center;transition:all .2s ease;background-color:#ffffff05}.drop-zone.dragging{border-color:#667eea;background-color:#667eea14;transform:scale(1.02)}.drop-zone.has-file{border-color:#4ade80;background-color:#4ade8008}.upload-icon{width:48px;height:48px;margin:0 auto .75rem;color:#667eea}.drop-text{font-size:1.05rem;margin-bottom:.4rem;font-weight:500}.or-text{margin:.8rem 0;opacity:.5}.file-input-label{display:inline-block;cursor:pointer}.file-input{display:none}.file-input-button{display:inline-block;padding:.6rem 1.1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;font-weight:500;transition:transform .15s ease}.file-input-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.file-info{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1rem}.file-icon{width:48px;height:48px;color:#4ade80}.file-details{text-align:left;max-width:calc(100% - 96px);box-sizing:border-box;overflow:hidden}.file-name{font-weight:600;margin-bottom:.25rem;white-space:normal;overflow-wrap:anywhere;word-break:break-all}.file-size{font-size:.9rem;opacity:.7}@media(prefers-color-scheme:light){.drop-zone{border-color:#ccc;background-color:#00000005}.drop-zone.dragging{background-color:#667eea0d}.drop-zone.has-file{background-color:#4ade800d}}.notice{border-radius:10px;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:.75rem auto;box-sizing:border-box;max-width:720px;width:calc(100% - 2rem)}.notice-body{flex:1 1 auto;text-align:center}.notice-title{font-weight:600;margin-bottom:.25rem}.notice-message{opacity:.95}.notice-warning{background:#facc150f;border:1px solid rgba(250,204,21,.14);color:#f59e0b}.notice-error{background:#dc26260f;border:1px solid rgba(220,38,38,.14);color:#f87171}.notice-info{background:#6366f10f;border:1px solid rgba(99,102,241,.12);color:#a78bfa}.notice-actions{display:flex;gap:.5rem;align-items:center}.notice-btn{border:none;padding:.45rem .65rem;border-radius:6px;cursor:pointer;font-weight:600}.notice-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.notice-btn-default{background:#ffffff0a;color:inherit}.notice-btn-danger{background:#dc262614;color:#dc2626}@media(prefers-color-scheme:light){.notice{color:inherit}}.encryption-form{background-color:#ffffff05;border-radius:12px;padding:1.25rem;border:1px solid rgba(255,255,255,.08)}.encryption-form h2{margin-bottom:1rem;font-size:1.25rem}.encryption-form form{display:flex;flex-direction:column;gap:1rem}.form-section{display:flex;flex-direction:column;gap:.4rem}.form-label{font-weight:500;display:flex;flex-direction:column;gap:.25rem}.label-hint{font-size:.85rem;font-weight:400;opacity:.7}.form-section input[type=password]{width:100%}.form-section.permissions{gap:.75rem}.form-section.permissions h3{font-size:1.1rem;margin-bottom:.5rem}.checkbox-label{display:flex;align-items:center;gap:.6rem;cursor:pointer;padding:0 .25rem;border-radius:6px;transition:background-color .15s ease}.checkbox-label:hover{background-color:#ffffff0d}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.checkbox-label span{font-size:.95rem}.encrypt-button{width:100%;padding:.75rem;font-size:1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;margin-top:.4rem;transition:all .2s ease}.encrypt-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.encrypt-button:disabled{opacity:.6;cursor:not-allowed}@media(prefers-color-scheme:light){.encryption-form{background-color:#00000005;border-color:#0000001a}.checkbox-label:hover{background-color:#0000000d}}
