*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--clr-bg: #0f1e38;--clr-surface: #1a2f52;--clr-surface-2: #0a1628;--clr-primary: #4f8ef7;--clr-primary-hover: #3070e0;--clr-primary-subtle: rgba(79, 142, 247, .12);--clr-accent: #f97316;--clr-accent-hover: #ea6c00;--clr-accent-subtle: rgba(249, 115, 22, .12);--clr-success: #22c55e;--clr-success-bg: rgba(34, 197, 94, .12);--clr-error: #f87171;--clr-error-bg: rgba(248, 113, 113, .12);--clr-text: #e2e8f0;--clr-muted: #8ea8c3;--clr-border: #2a4170;--header-h: 56px;--bottom-nav-h: 64px;--safe-bottom: env(safe-area-inset-bottom, 0px);--radius: 12px;--radius-sm: 8px;--radius-pill: 999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .45);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-focus: 0 0 0 3px rgba(79, 142, 247, .4);--dur-micro: .12s;--dur-std: .2s}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;line-height:1.5;color:var(--clr-text);background:var(--clr-bg);-webkit-font-smoothing:antialiased}.app-shell{display:flex;flex-direction:column;height:100%}.main-content{flex:1;overflow-y:auto;padding-bottom:var(--safe-bottom)}.header{flex-shrink:0;height:var(--header-h);background:var(--clr-surface-2);color:var(--clr-text);display:flex;align-items:center;padding:0 1rem;border-bottom:1px solid var(--clr-border);z-index:10}.header-brand{display:flex;align-items:baseline;gap:.4rem;flex:1}.header-logo{font-size:1.125rem;font-weight:800;letter-spacing:.06em;color:#fff}.header-by{font-size:.65rem;font-weight:400;color:var(--clr-muted);letter-spacing:.03em}.header-user{display:flex;align-items:center;gap:.5rem}.header-avatar{width:32px;height:32px;border-radius:50%;background:var(--clr-primary);color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;letter-spacing:.02em;flex-shrink:0}.header-user-name{font-size:.875rem;font-weight:500}.header-logout{background:none;border:1px solid var(--clr-border);color:var(--clr-muted);font-size:.75rem;padding:.25rem .75rem;border-radius:var(--radius-pill);cursor:pointer;min-height:44px;transition:background var(--dur-micro),color var(--dur-micro),border-color var(--dur-micro)}.header-logout:hover{background:var(--clr-surface);color:var(--clr-text)}.header-logout:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.login-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse 80% 60% at 50% -10%,rgba(79,142,247,.18) 0%,transparent 70%),var(--clr-bg);padding:1.5rem}@media (min-width: 768px){.login-screen{max-width:480px;min-height:100dvh;margin:0 auto;box-shadow:0 0 0 1px var(--clr-border),0 4px 32px #00000080}}.login-card{width:100%;max-width:380px;background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);box-shadow:var(--shadow-sm),0 0 0 1px #4f8ef70f;padding:2rem 1.5rem}.login-brand{margin-bottom:1.75rem}.login-logo{font-size:2rem;font-weight:800;letter-spacing:.08em;color:var(--clr-accent);line-height:1}.login-by{font-size:.7rem;font-weight:400;color:var(--clr-muted);letter-spacing:.04em;margin-top:2px}.login-title{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--clr-text)}.login-subtitle{font-size:.875rem;color:var(--clr-muted);margin-bottom:1.5rem;line-height:1.5}.form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--clr-muted)}.form-group input{padding:.75rem;border:1.5px solid var(--clr-border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--clr-text);background:var(--clr-surface-2);transition:border-color var(--dur-micro),box-shadow var(--dur-micro);outline:none}.form-group input:focus{border-color:var(--clr-primary);box-shadow:0 0 0 3px #4f8ef733}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-error{font-size:.875rem;color:var(--clr-error);margin-bottom:.75rem}.login-submit{width:100%;margin-top:.5rem}.login-divider{display:flex;align-items:center;gap:.75rem;margin:1.25rem 0;color:var(--clr-muted);font-size:.8rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--clr-border)}.btn-secondary{display:flex;align-items:center;justify-content:center;gap:.6rem;background:var(--clr-surface-2);color:var(--clr-text);border:1.5px solid var(--clr-border);transition:background var(--dur-micro),border-color var(--dur-micro),transform var(--dur-micro)}.btn-secondary:hover:not(:disabled){background:var(--clr-surface);border-color:var(--clr-primary)}.btn-secondary:active:not(:disabled){transform:scale(.985)}.btn-secondary:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.bottom-nav{flex-shrink:0;height:calc(var(--bottom-nav-h) + var(--safe-bottom));padding-bottom:var(--safe-bottom);background:var(--clr-surface-2);border-top:1px solid var(--clr-border);display:flex}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;text-decoration:none;color:var(--clr-muted);font-size:.6875rem;font-weight:500;transition:color var(--dur-micro),box-shadow var(--dur-micro);-webkit-tap-highlight-color:transparent;position:relative}.nav-item svg{width:24px;height:24px;stroke-width:1.75}.nav-item--active,.nav-item:hover{color:var(--clr-primary)}.nav-item--active:before{content:"";position:absolute;top:0;left:20%;right:20%;height:2px;background:var(--clr-primary);border-radius:0 0 var(--radius-sm) var(--radius-sm)}.nav-item:focus-visible{outline:none;color:var(--clr-primary);box-shadow:inset 0 0 0 2px var(--clr-primary)}.page{padding:1.5rem 1rem;min-height:100%}.scan-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100%;gap:2rem;padding:2rem 1rem}.scan-cta{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;max-width:320px;width:100%}.scan-icon-circle{width:80px;height:80px;border-radius:50%;background:var(--clr-surface);border:2px solid var(--clr-border);display:flex;align-items:center;justify-content:center;color:var(--clr-primary);margin-bottom:.25rem}.scan-icon-circle svg{width:40px;height:40px}.scan-cta h1{font-size:1.375rem;font-weight:700}.scan-cta p{color:var(--clr-muted);font-size:.875rem;line-height:1.5}.scan-options{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:320px}.scan-option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;border-radius:var(--radius);cursor:pointer;transition:opacity var(--dur-micro),transform var(--dur-micro),background var(--dur-micro),box-shadow var(--dur-micro);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.scan-option--primary{background:var(--clr-accent);color:#fff;padding:1.5rem 1rem;font-weight:700;font-size:1.0625rem;box-shadow:0 4px 20px #f9731640}.scan-option--primary:hover{background:var(--clr-accent-hover);transform:translateY(-2px);box-shadow:0 6px 24px #f9731659}.scan-option--primary:active{transform:scale(.97) translateY(0);box-shadow:0 2px 8px #f9731633;opacity:1}.scan-option--primary:focus-visible{outline:none;box-shadow:0 0 0 3px #f9731680}.scan-option--primary .scan-option-icon svg{width:38px;height:38px}.scan-options-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.scan-option--secondary{background:var(--clr-surface);border:1.5px solid var(--clr-border);color:var(--clr-muted);padding:1.25rem .75rem;font-weight:500;font-size:.875rem}.scan-option--secondary:hover{background:var(--clr-primary-subtle);border-color:var(--clr-primary);color:var(--clr-primary);transform:translateY(-1px)}.scan-option--secondary:active{transform:scale(.97);opacity:.85}.scan-option--secondary:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.scan-option-icon{display:flex;align-items:center;justify-content:center}.scan-option-icon svg{width:26px;height:26px}.scan-option-label{line-height:1}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.75rem;padding:3rem 1rem;color:var(--clr-muted)}.empty-state svg{width:56px;height:56px;opacity:.4}.empty-state p{font-size:.9rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:var(--radius);font-size:1rem;font-family:inherit;font-weight:600;cursor:pointer;transition:background var(--dur-micro),opacity var(--dur-micro),transform var(--dur-micro),box-shadow var(--dur-micro);-webkit-tap-highlight-color:transparent}.btn:active:not(:disabled){opacity:.88;transform:scale(.97)}.btn:disabled,button:disabled{cursor:not-allowed;opacity:.45}.btn-primary{background:var(--clr-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--clr-accent-hover);transform:translateY(-1px);box-shadow:0 4px 16px #f9731659}.btn-primary:active:not(:disabled){transform:scale(.985) translateY(0);box-shadow:none}.btn-primary:focus-visible{outline:none;box-shadow:0 0 0 3px #f9731666}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-lg{padding:.9rem 2rem;font-size:1.0625rem;border-radius:999px;width:100%;max-width:280px}.btn-outline{background:transparent;color:var(--clr-primary);border:2px solid var(--clr-primary)}.btn-outline:hover{background:var(--clr-primary-subtle)}.btn-outline:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn-success{background:var(--clr-success);color:#fff;border:none;border-radius:var(--radius);padding:.5rem 1rem;font-size:.875rem;font-weight:600;cursor:pointer;min-width:80px;min-height:44px;-webkit-tap-highlight-color:transparent;transition:background var(--dur-micro),transform var(--dur-micro)}.btn-success:hover:not(:disabled){background:#16a34a}.btn-success:active:not(:disabled){transform:scale(.97)}.btn-success:focus-visible{outline:none;box-shadow:0 0 0 3px #22c55e66}.camera-screen{position:fixed;top:var(--header-h);left:0;right:0;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom));z-index:50;display:flex;flex-direction:column;background:#000}.camera-screen--fallback{align-items:center;justify-content:center;gap:1.5rem;padding:2rem}.camera-error-msg{color:#fff;text-align:center;font-size:.9rem;line-height:1.6}.camera-viewfinder{flex:1;position:relative;overflow:hidden}.camera-video{width:100%;height:100%;object-fit:cover}.camera-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.875rem;background:#00000080}.camera-pages-strip{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#000000b3;overflow-x:auto}.page-thumb{width:44px;height:58px;object-fit:cover;border-radius:4px;border:2px solid rgba(255,255,255,.8);flex-shrink:0}.pages-count{color:#fffc;font-size:.75rem;font-weight:600;white-space:nowrap;flex-shrink:0}.camera-controls{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#000}.camera-spacer{min-width:80px}.btn-capture{width:72px;height:72px;border-radius:50%;border:4px solid rgba(255,255,255,.85);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;flex-shrink:0;-webkit-tap-highlight-color:transparent;transition:opacity .15s}.btn-capture:disabled{opacity:.3;cursor:not-allowed}.btn-capture:not(:disabled):active{opacity:.7}.btn-capture-ring{display:block;width:56px;height:56px;border-radius:50%;background:#fff}.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45);border-radius:var(--radius);padding:.5rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer;min-width:80px;min-height:44px;-webkit-tap-highlight-color:transparent;transition:background var(--dur-micro)}.btn-ghost:hover{background:#ffffff1f}.btn-ghost:focus-visible{outline:none;box-shadow:0 0 0 2px #fff9}.crop-screen{position:fixed;top:var(--header-h);left:0;right:0;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom));z-index:50;display:flex;flex-direction:column;background:#000}.crop-image-area{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.crop-wrapper{position:relative;max-width:100%;max-height:100%;line-height:0}.crop-img{display:block;max-width:100%;max-height:calc(100dvh - var(--header-h) - var(--bottom-nav-h) - 72px);object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.crop-overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.crop-handle{position:absolute;transform:translate(-50%,-50%);touch-action:none;z-index:10}.crop-handle--corner{width:28px;height:28px;border-radius:50%;background:#fff;border:3px solid var(--clr-accent);cursor:grab;box-shadow:0 2px 8px #00000073}.crop-handle--corner:active{cursor:grabbing;transform:translate(-50%,-50%) scale(1.25)}.crop-handle--side{background:#ffffffe6;border:2px solid rgba(249,115,22,.7);border-radius:var(--radius-sm);box-shadow:0 1px 5px #0006}.crop-handle--side:active{transform:translate(-50%,-50%) scale(1.15)}.crop-handle--ns{width:38px;height:14px;cursor:ns-resize}.crop-handle--ew{width:14px;height:38px;cursor:ew-resize}.crop-controls{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:#000;flex-shrink:0}.crop-hint{color:#ffffffa6;font-size:.75rem;text-align:center}.done-screen h1{font-size:1.25rem;font-weight:700;margin-bottom:.25rem}.done-subtitle{color:var(--clr-muted);font-size:.9rem;margin-bottom:.75rem}.done-pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;margin-bottom:1rem;padding-top:4px}.done-page-card-wrap{position:relative}.done-page-card{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;padding:0;font:inherit;display:block;width:100%;position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:3 / 4;background:var(--clr-surface);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform var(--dur-std),box-shadow var(--dur-std)}.done-page-delete{position:absolute;top:-8px;right:-8px;z-index:10;width:28px;height:28px;border-radius:50%;border:2px solid var(--clr-bg);background:var(--clr-error);color:#fff;font-size:.65rem;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 4px #0006;transition:background var(--dur-micro),transform var(--dur-micro);padding:10px;margin:-10px}.done-page-delete:hover{background:#dc2626}.done-page-delete:active{transform:scale(.9)}.done-page-delete:focus-visible{outline:none;box-shadow:0 0 0 3px #f8717180}.done-page-card:hover{transform:scale(1.04) translateY(-1px);box-shadow:var(--shadow-md)}.done-page-card:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.done-page-card:active{transform:scale(.97)}.done-page-card img{width:100%;height:100%;object-fit:cover}.done-page-label{position:absolute;bottom:0;left:0;right:0;background:#0000008c;color:#fff;font-size:.7rem;text-align:center;padding:3px 0}.done-page-add{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px dashed var(--clr-border);background:transparent;border-radius:var(--radius-sm);aspect-ratio:3 / 4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;color:var(--clr-muted);font-size:.75rem;transition:border-color var(--dur-micro),color var(--dur-micro)}.done-page-add:hover{border-color:var(--clr-primary);color:var(--clr-primary)}.done-page-add-icon{font-size:1.75rem;line-height:1}.add-page{margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.add-page-label{font-size:.8125rem;font-weight:600;color:var(--clr-muted);margin-bottom:.2rem}.add-page-options{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.add-page .scan-option--primary{padding:.65rem 1rem;font-size:.9375rem}.add-page .scan-option--primary .scan-option-icon svg{width:26px;height:26px}.add-page-options .scan-option--secondary{padding:.65rem .5rem;gap:.4rem}.add-page-options .scan-option-icon svg{width:22px;height:22px}.done-actions{display:flex;flex-direction:column;align-items:center;gap:.5rem}.btn-discard{background:none;border:1.5px solid var(--clr-border);border-radius:var(--radius);color:var(--clr-muted);font-family:inherit;font-size:.8125rem;font-weight:500;padding:.5rem 1.25rem;margin-top:.25rem;cursor:pointer;transition:border-color var(--dur-micro),color var(--dur-micro);-webkit-tap-highlight-color:transparent}.btn-discard:hover{border-color:var(--clr-error);color:var(--clr-error)}.btn-discard:focus-visible{outline:none;box-shadow:0 0 0 3px #f871714d;border-radius:var(--radius)}.btn-discard--danger{border-color:var(--clr-error);color:var(--clr-error);margin-top:0}.btn-discard--danger:hover{background:var(--clr-error-bg)}.discard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem;animation:overlay-in var(--dur-std) ease}.discard-confirm{width:100%;max-width:320px;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;border:1.5px solid var(--clr-error);border-radius:var(--radius);background:var(--clr-surface);box-shadow:var(--shadow-md);animation:panel-up var(--dur-std) ease}.discard-confirm-text{font-size:1rem;color:var(--clr-text);font-weight:600;text-align:center}.discard-confirm-sub{font-size:.8125rem;color:var(--clr-muted);text-align:center;margin-bottom:.5rem}.discard-confirm-actions{display:flex;gap:.75rem;width:100%}.discard-confirm-actions .btn-discard--danger,.discard-confirm-actions .btn{flex:1}.pdf-ready-info{font-size:.9rem;color:var(--clr-success);background:var(--clr-success-bg);padding:.4rem .9rem;border-radius:var(--radius)}.pdf-ready-buttons{display:flex;gap:.75rem;width:100%;max-width:340px}.pdf-ready-buttons .btn{flex:1}.pdf-error{font-size:.875rem;color:var(--clr-error);text-align:center}.upload-success{font-size:.9rem;color:var(--clr-success);background:var(--clr-success-bg);padding:.4rem .9rem;border-radius:var(--radius);text-align:center}.upload-error{font-size:.875rem;color:var(--clr-error);text-align:center}.pdf-preview-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:var(--clr-surface-2);display:flex;flex-direction:column}.pdf-preview-bar{flex-shrink:0;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px));background:var(--clr-surface-2);border-bottom:1px solid var(--clr-border);color:var(--clr-text);gap:8px}.pdf-preview-back{background:none;border:none;color:var(--clr-primary);font-size:.95rem;font-family:inherit;cursor:pointer;padding:4px 0;text-align:left}.pdf-preview-title{font-size:.9rem;font-weight:600;text-align:center;white-space:nowrap}.pdf-preview-size{font-size:.8rem;color:var(--clr-muted);text-align:right}.pdf-preview-body{flex:1;min-height:0;background:#1a1a1a}.pdf-embed{width:100%;height:100%;border:none;display:block}.pdf-preview-footer{flex-shrink:0;display:flex;justify-content:center;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));background:var(--clr-surface-2);border-top:1px solid var(--clr-border)}.preview-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000;display:flex;flex-direction:column}.preview-bar{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;padding-top:calc(12px + env(safe-area-inset-top,0px));background:#000000d9}.preview-counter{color:#fff;font-size:.875rem;font-weight:600}.preview-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:none;color:#ffffffd9;font-size:.875rem;font-family:inherit;font-weight:500;padding:6px 12px;border-radius:var(--radius-sm);cursor:pointer;min-height:44px;-webkit-tap-highlight-color:transparent;transition:background var(--dur-micro)}.preview-btn:hover{background:#ffffff1f}.preview-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #fff9}.preview-btn--delete{color:var(--clr-error)}.preview-body{flex:1;display:flex;align-items:center;justify-content:center;padding:12px;overflow:hidden}.preview-img{max-width:100%;max-height:100%;object-fit:contain;border-radius:4px}.preview-nav{flex-shrink:0;display:flex;justify-content:space-between;padding:12px 24px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));background:#000000d9;min-height:56px;align-items:center}.preview-nav-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff;font-size:.875rem;font-family:inherit;font-weight:500;padding:8px 20px;border-radius:var(--radius);cursor:pointer;min-height:44px;-webkit-tap-highlight-color:transparent;transition:background var(--dur-micro)}.preview-nav-btn:hover{background:#ffffff1a}.preview-nav-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #fff9}.documents-page h1{font-size:1.25rem;font-weight:700;margin-bottom:1.25rem}.doc-list{list-style:none;display:flex;flex-direction:column;gap:12px}.doc-card{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow-sm);transition:box-shadow var(--dur-std),transform var(--dur-std)}.doc-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.doc-card-top{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.doc-name{font-size:1rem;font-weight:600;color:var(--clr-text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.doc-card-end{display:flex;align-items:center;gap:6px;flex-shrink:0}.doc-card-chevron{width:16px;height:16px;color:var(--clr-muted);flex-shrink:0}.doc-meta{font-size:.8125rem;color:var(--clr-muted)}.doc-card-footer{margin-top:4px;display:flex;justify-content:flex-end}.doc-status{display:inline-flex;align-items:center;gap:5px;font-size:.6875rem;font-weight:600;padding:3px 9px;border-radius:999px;white-space:nowrap;flex-shrink:0}.doc-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.doc-status--done{background:var(--clr-success-bg);color:var(--clr-success)}.doc-status--done .doc-status-dot{background:var(--clr-success)}.doc-status--processing{background:#f9731626;color:#fb923c}.doc-status--processing .doc-status-dot{background:var(--clr-accent)}.doc-status--error{background:var(--clr-error-bg);color:var(--clr-error)}.doc-status--error .doc-status-dot{background:var(--clr-error)}.doc-status--pending{background:#8ea8c31a;color:var(--clr-muted)}.doc-status--pending .doc-status-dot{background:var(--clr-muted)}@media (prefers-reduced-motion: no-preference){.doc-status--processing .doc-status-dot{animation:status-pulse 1.4s ease-in-out infinite}}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.3}}.btn-download{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border:1.5px solid var(--clr-primary);border-radius:var(--radius);background:transparent;color:var(--clr-primary);font-size:.8125rem;font-family:inherit;font-weight:600;cursor:pointer;min-height:44px;transition:background var(--dur-micro),color var(--dur-micro);-webkit-tap-highlight-color:transparent}.btn-download:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.btn-download:hover:not(:disabled){background:var(--clr-primary);color:#fff}.btn-download:disabled{border-color:var(--clr-border);color:var(--clr-muted);cursor:not-allowed;opacity:.6}.toast{position:fixed;bottom:calc(var(--bottom-nav-h) + var(--safe-bottom) + 14px);left:50%;transform:translate(-50%);background:var(--clr-surface-2);border:1px solid var(--clr-border);color:var(--clr-text);padding:10px 20px;border-radius:999px;font-size:.875rem;font-weight:500;white-space:nowrap;z-index:300;box-shadow:0 4px 20px #00000080;animation:toast-in .2s ease;pointer-events:none}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.doc-badge{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;font-weight:600;padding:4px 10px;border-radius:var(--radius-pill);white-space:nowrap;flex-shrink:0;border:1px solid transparent}.doc-badge-dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex-shrink:0}.doc-badge-dot--pulse{background:var(--clr-primary)}@media (prefers-reduced-motion: no-preference){.doc-badge-dot--pulse{animation:status-pulse 1.4s ease-in-out infinite}}.doc-badge--proc-procesando{background:var(--clr-primary-subtle);color:var(--clr-primary)}.doc-badge--proc-procesado{background:var(--clr-success-bg);color:var(--clr-success)}.doc-badge--proc-error{background:var(--clr-error-bg);color:var(--clr-error)}.doc-badge--ara-no_enviado{background:#8ea8c31a;color:var(--clr-muted);border-color:#8ea8c340}.doc-badge--ara-en_revision{background:#f59e0b1f;color:#f59e0b;border-color:#f59e0b4d}.doc-badge--ara-aprobado{background:var(--clr-success-bg);color:var(--clr-success);border-color:#22c55e4d}.doc-badge--ara-rechazado{background:var(--clr-error-bg);color:var(--clr-error);border-color:#f871714d}.doc-card--clickable{cursor:pointer;position:relative}.doc-card--clickable:hover{border-color:var(--clr-primary)}.doc-card--clickable:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.doc-card--procesando{opacity:.75}.doc-card--error{border-color:var(--clr-error-bg)}.doc-processing-label{display:flex;align-items:center;gap:7px;font-size:.875rem;font-weight:500;color:var(--clr-primary)}.doc-error-label{font-size:.875rem;font-weight:600;color:var(--clr-error)}.doc-card--skeleton{pointer-events:none}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--clr-surface) 25%,var(--clr-border) 50%,var(--clr-surface) 75%);background-size:200% 100%}@media (prefers-reduced-motion: no-preference){.skeleton{animation:skeleton-shimmer 1.4s ease-in-out infinite}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton--title{height:18px;width:55%;margin-bottom:10px}.skeleton--meta{height:13px;width:70%;margin-bottom:12px}.skeleton--badges{height:22px;width:40%}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0000008c;display:flex;align-items:flex-end;animation:overlay-in var(--dur-std) ease}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.detail-panel{width:100%;max-width:480px;margin:0 auto;max-height:85dvh;background:var(--clr-surface);border-radius:var(--radius) var(--radius) 0 0;border-top:1px solid var(--clr-border);display:flex;flex-direction:column;animation:panel-up var(--dur-std) ease;padding-bottom:var(--safe-bottom)}@keyframes panel-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--clr-border);flex-shrink:0}.detail-title{font-size:1.125rem;font-weight:700;line-height:1.3}.detail-subtitle{font-size:.8125rem;color:var(--clr-muted);margin-top:3px}.detail-close{background:none;border:none;color:var(--clr-muted);font-size:1rem;cursor:pointer;padding:4px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);flex-shrink:0;transition:color var(--dur-micro),background var(--dur-micro)}.detail-close:hover{color:var(--clr-text);background:var(--clr-surface-2)}.detail-close:focus-visible{outline:none;box-shadow:var(--shadow-focus)}.detail-body{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.detail-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.detail-label{font-size:.8125rem;color:var(--clr-muted);font-weight:500;flex-shrink:0}.detail-value{font-size:.9rem;font-weight:600;color:var(--clr-text)}.detail-rechazo{background:var(--clr-error-bg);border:1px solid rgba(248,113,113,.2);border-radius:var(--radius-sm);padding:.875rem 1rem;display:flex;flex-direction:column;gap:.4rem}.detail-rechazo-texto{font-size:.875rem;color:var(--clr-error);line-height:1.5}.detail-footer{padding:1rem 1.25rem;border-top:1px solid var(--clr-border);flex-shrink:0;display:flex;justify-content:center}.header-avatar-btn{background:none;border:none;padding:0;cursor:pointer;border-radius:50%;display:flex;-webkit-tap-highlight-color:transparent}.header-avatar-btn:focus-visible{outline:none;box-shadow:var(--shadow-focus);border-radius:50%}.header-avatar img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-page{display:flex;flex-direction:column;gap:0;padding-bottom:1.5rem}.profile-avatar-section{display:flex;flex-direction:column;align-items:center;padding:1.5rem 0 1rem;gap:.5rem}.profile-avatar-wrap{position:relative;width:84px;height:84px}.profile-avatar{width:84px;height:84px;border-radius:50%;background:var(--clr-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 0 0 3px var(--clr-surface),0 0 0 5px var(--clr-primary)}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-avatar-initials{color:#fff;font-size:1.5rem;font-weight:700;letter-spacing:.02em}.profile-avatar-edit{position:absolute;bottom:0;right:0;width:28px;height:28px;border-radius:50%;background:var(--clr-surface-2);border:2px solid var(--clr-bg);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--dur-micro)}.profile-avatar-edit:hover{background:var(--clr-surface)}.profile-avatar-edit svg{width:14px;height:14px;stroke:var(--clr-text)}.profile-avatar-hint{font-size:.75rem;color:var(--clr-muted)}.profile-section{padding:1rem 1.25rem;border-top:1px solid var(--clr-border);display:flex;flex-direction:column;gap:1rem}.profile-section-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--clr-muted)}.profile-field{display:flex;flex-direction:column;gap:.375rem}.profile-field label{font-size:.8125rem;font-weight:500;color:var(--clr-muted)}.profile-field input{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-sm);color:var(--clr-text);font-family:inherit;font-size:.9375rem;padding:.65rem .875rem;width:100%;outline:none;transition:border-color var(--dur-micro),box-shadow var(--dur-micro)}.profile-field input:focus-visible{border-color:var(--clr-primary);box-shadow:var(--shadow-focus)}.profile-input--disabled{opacity:.5;cursor:not-allowed}.profile-field-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.profile-input-wrap{position:relative}.profile-input-wrap input{padding-right:2.75rem}.profile-eye-btn{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;padding:.25rem;cursor:pointer;color:var(--clr-muted);display:flex;align-items:center;justify-content:center;transition:color var(--dur-micro)}.profile-eye-btn:hover{color:var(--clr-text)}.profile-eye-btn svg{width:18px;height:18px;stroke-width:2}.profile-eye-btn:focus-visible{outline:none;color:var(--clr-primary)}.profile-ara-note{font-size:.75rem;color:var(--clr-muted)}.profile-password-note{font-size:.8125rem;color:var(--clr-muted);line-height:1.5}.profile-password-link{color:var(--clr-primary);text-decoration:underline;cursor:pointer}.profile-save-bar{padding:1rem 1.25rem 0;border-top:1px solid var(--clr-border);margin-top:.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem}.profile-save-error{color:var(--clr-error, #f87171);font-size:.85rem;text-align:center}.admin-tabs{display:flex;gap:6px;margin-bottom:16px}.admin-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 4px;border-radius:var(--radius-sm);border:1.5px solid var(--clr-border);background:var(--clr-surface);color:var(--clr-muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.admin-tab--active{background:var(--clr-primary-subtle);border-color:var(--clr-primary);color:var(--clr-primary)}.admin-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 5px;border-radius:var(--radius-pill);background:var(--clr-primary);color:#fff;font-size:.75rem;font-weight:700}.admin-tab:not(.admin-tab--active) .admin-tab-count{background:var(--clr-border);color:var(--clr-muted)}.admin-panel{max-height:90dvh}.admin-body{display:flex;flex-direction:column;gap:14px}.admin-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.admin-field-group{display:flex;flex-direction:column;gap:4px}.admin-field-label{font-size:.78rem;font-weight:600;color:var(--clr-muted);text-transform:uppercase;letter-spacing:.04em}.admin-input{padding:8px 10px;border-radius:var(--radius-sm);border:1.5px solid var(--clr-border);background:var(--clr-surface-2);color:var(--clr-text);font-size:.9rem;width:100%;outline:none;transition:border-color .15s}.admin-input:focus{border-color:var(--clr-primary)}.admin-input--code{width:110px;flex-shrink:0}.admin-field-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.admin-candidatos{display:flex;flex-direction:column;gap:4px}.admin-candidato{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;border-radius:var(--radius-sm);border:1.5px solid var(--clr-border);background:var(--clr-surface-2);color:var(--clr-text);font-size:.875rem;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.admin-candidato:hover{border-color:var(--clr-primary);background:var(--clr-primary-subtle)}.admin-candidato--selected{border-color:var(--clr-primary);background:var(--clr-primary-subtle);color:var(--clr-primary)}.admin-candidato-desc{font-weight:500}.admin-candidato-meta{font-size:.75rem;color:var(--clr-muted);white-space:nowrap;margin-left:8px}.admin-candidato--selected .admin-candidato-meta{color:var(--clr-primary)}.admin-candidato-manual-btn{background:none;border:none;color:var(--clr-primary);font-size:.8rem;cursor:pointer;padding:4px 0;text-align:left;text-decoration:underline}.admin-checkbox-label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--clr-text);cursor:pointer}.admin-buscador{position:relative;flex:1;min-width:0}.admin-buscador-loading{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--clr-muted);font-size:1rem;pointer-events:none}.admin-buscador-list{position:absolute;z-index:20;top:calc(100% + 2px);left:0;right:0;margin:0;padding:4px;list-style:none;max-height:260px;overflow-y:auto;background:var(--clr-surface);border:1.5px solid var(--clr-border);border-radius:var(--radius-sm);box-shadow:0 8px 24px #0000002e}.admin-buscador-item{display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;border-radius:var(--radius-sm);background:none;color:var(--clr-text);font-size:.85rem;text-align:left;cursor:pointer}.admin-buscador-item:hover{background:var(--clr-primary-subtle);color:var(--clr-primary)}.admin-buscador-item-desc{font-weight:500}.admin-buscador-item-cod{font-size:.75rem;color:var(--clr-muted);white-space:nowrap}.admin-buscador-item:hover .admin-buscador-item-cod{color:var(--clr-primary)}.btn-secondary{padding:12px 16px;border-radius:var(--radius);border:1.5px solid var(--clr-border);background:var(--clr-surface);color:var(--clr-text);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:var(--clr-surface-2)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}@media (min-width: 768px){.app-shell{max-width:480px;margin:0 auto;box-shadow:0 0 0 1px var(--clr-border),0 4px 32px #00000080}}
