*,*:before,*:after{box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light dark;--safe-top: var(--safe-area-inset-top, env(safe-area-inset-top, 0px));--safe-right: var(--safe-area-inset-right, env(safe-area-inset-right, 0px));--safe-bottom: var(--safe-area-inset-bottom, env(safe-area-inset-bottom, 0px));--safe-left: var(--safe-area-inset-left, env(safe-area-inset-left, 0px));--text: rgba(255, 255, 255, .9);--muted: rgba(255, 255, 255, .6);--bg: #1a1a1a;--surface: #242424;--border: rgba(255, 255, 255, .12);--hover: rgba(255, 255, 255, .06);--link: #646cff;--primary: #535bf2;--primary-contrast: #fff;--error: #f87171;--error-bg: rgba(248, 113, 113, .15);--progress-success: #4ade80;--input-border: var(--border);color:var(--text);background-color:var(--bg)}@media(prefers-color-scheme:light){:root:not([data-theme]){--text: #1a1a1a;--muted: #666;--bg: #f5f5f5;--surface: #fff;--border: rgba(0, 0, 0, .12);--hover: rgba(0, 0, 0, .04);--link: #535bf2;--primary: #4353e2;--primary-contrast: #fff;--error: #dc2626;--error-bg: rgba(220, 38, 38, .1);--progress-success: #16a34a;--input-border: var(--border)}}[data-theme=light]{--text: #1a1a1a;--muted: #666;--bg: #f5f5f5;--surface: #fff;--border: rgba(0, 0, 0, .12);--hover: rgba(0, 0, 0, .04);--link: #535bf2;--primary: #4353e2;--primary-contrast: #fff;--error: #dc2626;--error-bg: rgba(220, 38, 38, .1);--progress-success: #16a34a;--input-border: var(--border);color:var(--text);background-color:var(--bg)}[data-theme=dark]{--text: rgba(255, 255, 255, .9);--muted: rgba(255, 255, 255, .6);--bg: #1a1a1a;--surface: #242424;--border: rgba(255, 255, 255, .12);--hover: rgba(255, 255, 255, .06);--link: #646cff;--primary: #535bf2;--primary-contrast: #fff;--error: #f87171;--error-bg: rgba(248, 113, 113, .15);--progress-success: #4ade80;--input-border: var(--border);color:var(--text);background-color:var(--bg)}[data-comfortable-text=true]{font-size:1.0625rem;line-height:1.6}[data-comfortable-text=true] .page-header h1{font-size:1.25rem}a{font-weight:500;color:var(--link);text-decoration:inherit}a:hover{text-decoration:underline}html{overflow-x:hidden}html[data-native=true]{padding-top:max(1.75rem,var(--safe-top));padding-right:max(.5rem,var(--safe-right));padding-bottom:max(.5rem,var(--safe-bottom));padding-left:max(.5rem,var(--safe-left))}html[data-native=true][data-platform=android]{--input-border: #3b82f6}html[data-native=true][data-platform=android] input:not([type=checkbox]):not([type=radio]),html[data-native=true][data-platform=android] textarea,html[data-native=true][data-platform=android] select{border:1px solid var(--input-border);border-radius:6px}html[data-native=true][data-platform=android] input:not([type=checkbox]):not([type=radio]):focus,html[data-native=true][data-platform=android] textarea:focus,html[data-native=true][data-platform=android] select:focus{outline:2px solid var(--input-border);outline-offset:2px}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid var(--border);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--surface);color:var(--text);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--link)}button:focus,button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.onboarding-ease-out{--onboarding-ease: cubic-bezier(.33, 1, .68, 1)}.onboarding-ease-in{--onboarding-ease-in: cubic-bezier(.32, 0, .67, 0)}.onboarding{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:max(2rem,var(--safe-top)) max(2rem,var(--safe-right)) max(2rem,var(--safe-bottom)) max(2rem,var(--safe-left));text-align:center}.onboarding-app-name{font-size:2.5rem;font-weight:700;margin:0 0 1rem}.onboarding-logo{max-width:min(360px,92vw);width:min(360px,92vw);height:auto;min-height:155px;display:block}.onboarding-step{display:flex;flex-direction:column;align-items:center;width:100%;max-width:24rem}.onboarding-step-enter{animation:onboarding-step-enter .42s var(--onboarding-ease, cubic-bezier(.33, 1, .68, 1)) forwards}.onboarding-step-enter .onboarding-reveal{opacity:0;animation:onboarding-reveal .5s var(--onboarding-ease, cubic-bezier(.33, 1, .68, 1)) forwards}.onboarding-step-enter .onboarding-reveal-1{animation-delay:60ms}.onboarding-step-enter .onboarding-reveal-2{animation-delay:.14s}.onboarding-step-enter .onboarding-reveal-3{animation-delay:.22s}.onboarding-step-enter .onboarding-reveal-4{animation-delay:.3s}.onboarding-step-exit{animation:onboarding-step-exit .28s var(--onboarding-ease-in, cubic-bezier(.32, 0, .67, 0)) forwards}@keyframes onboarding-step-enter{0%{opacity:0;transform:scale(.97);filter:blur(4px)}to{opacity:1;transform:scale(1);filter:blur(0)}}@keyframes onboarding-reveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes onboarding-step-exit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.98)}}@media(prefers-reduced-motion:reduce){.onboarding-step-enter,.onboarding-step-enter .onboarding-reveal,.onboarding-step-exit{animation-duration:.01ms}.onboarding-step-enter .onboarding-reveal{opacity:1;transform:none}}.onboarding-heading{font-size:1.75rem;margin:0 0 1rem}.onboarding-copy{font-size:1.1rem;margin:0 0 2rem;max-width:24rem;line-height:1.5}.onboarding-name form{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.onboarding-name form label{width:100%}.onboarding-name input{width:100%;max-width:14rem;padding:.6rem .875rem;font-size:1rem;border:1px solid var(--input-border);border-radius:6px}.onboarding-name .btn{min-width:10rem}.onboarding-goal form{display:flex;flex-direction:column;align-items:center;gap:1rem;width:100%}.onboarding-goal form label{width:100%}.onboarding-goal input[type=number]{width:100%;max-width:10rem;padding:.6rem .875rem;font-size:1rem;border:1px solid var(--input-border);border-radius:6px}.onboarding-goal-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.onboarding-goal .btn{min-width:8rem}.onboarding-disclaimer{font-size:.9rem;margin:1rem 0 0;max-width:20rem;text-align:center}.layout{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;width:100%}.layout-header{padding-top:max(1.6rem,var(--safe-top));padding-right:max(1.65rem,var(--safe-right));padding-bottom:1.25rem;padding-left:max(1.65rem,var(--safe-left));border-bottom:1px solid var(--border);background:var(--surface)}.layout-header-inner{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-width:0;width:100%}.layout-brand{flex-shrink:0;min-width:6.75rem;display:inline-flex;align-items:center;font-weight:600;font-size:1.125rem;color:inherit;text-decoration:none;overflow:visible}.layout-brand:hover{text-decoration:none;opacity:.9}.layout-logo-wrap{position:relative;display:block;height:2.328rem;width:2.328rem}.layout-logo-wrap .layout-logo{position:absolute;top:0;left:0}.layout-logo{height:2.328rem;width:auto;display:block;object-fit:contain;object-position:left center;transform:scale(2.91);transform-origin:left center}.layout-logo-dark{display:block;mix-blend-mode:lighten}.layout-logo-light,[data-theme=light] .layout-logo-dark{display:none}[data-theme=light] .layout-logo-light{display:block}.layout-nav{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;flex-wrap:wrap;flex-shrink:1;min-width:0;margin-left:auto}.layout-nav a{color:var(--link);min-height:44px;min-width:44px;display:inline-flex;align-items:center;padding:.25rem .5rem}.layout-settings{display:inline-flex;align-items:center;justify-content:center;min-height:44px;min-width:44px;padding:.25rem;text-decoration:none}.layout-settings:hover{color:var(--text)}.layout-signout{flex-shrink:0;background:none;border:none;color:var(--muted);cursor:pointer;min-height:44px;min-width:44px;padding:.25rem .5rem;font-size:.9rem;white-space:nowrap;display:inline-flex;align-items:center}.layout-signout:hover{color:var(--text)}.layout-main{flex:1;min-height:0;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:4rem;padding-right:max(1.5rem,var(--safe-right));padding-bottom:max(2.25rem,var(--safe-bottom));padding-left:max(1.5rem,var(--safe-left));max-width:56rem;margin:0 auto;width:100%}@media(max-width:520px){.layout-logo-wrap{height:2rem;width:2rem}.layout-logo{height:2rem;transform:scale(2.91)}.layout-brand{min-width:5.85rem}}@media(max-width:400px){.layout-logo-wrap{height:1.94rem;width:1.94rem}.layout-logo{height:1.94rem;transform:scale(2.91)}.layout-brand{min-width:5.65rem}}@media(max-width:480px){html:not([data-native=true]) .layout-header{padding-left:max(1rem,var(--safe-left));padding-right:max(1rem,var(--safe-right))}.layout-nav a{padding:.25rem .35rem}.layout-signout{padding:.25rem .35rem;font-size:.85rem}html:not([data-native=true]) .layout-main{padding-top:3.5rem;padding-right:max(1rem,var(--safe-right));padding-bottom:max(1.75rem,var(--safe-bottom));padding-left:max(1rem,var(--safe-left))}}html[data-native=true] .layout-nav-dropdown{position:relative}html[data-native=true] .layout-nav-menu-btn{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:.5rem;background:none;border:none;color:inherit;cursor:pointer}html[data-native=true] .layout-nav-menu-btn:hover{opacity:.85}.nav-menu-backdrop{position:fixed;inset:0;background:transparent;z-index:999}.nav-menu-sheet{position:absolute;top:100%;right:0;margin-top:.25rem;min-width:12rem;max-height:70vh;overflow-y:auto;background:var(--surface);border-radius:8px;border:1px solid var(--border);z-index:1000;box-shadow:0 4px 20px #0003}.nav-menu-list{display:flex;flex-direction:column}.nav-menu-item,.nav-menu-item-settings,.nav-menu-item-signout{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem 1.25rem;color:inherit;text-decoration:none;background:none;border:none;border-bottom:1px solid var(--border);font-size:1rem;font-family:inherit;cursor:pointer;text-align:left;transition:background-color .15s ease}.nav-menu-item:last-child,.nav-menu-item-signout{border-bottom:none}.nav-menu-item:hover,.nav-menu-item-settings:hover,.nav-menu-item-signout:hover{background:var(--hover)}.nav-menu-item-settings svg{flex-shrink:0;opacity:.7}.nav-menu-item-signout{color:var(--muted)}.nav-menu-item-signout:hover{color:var(--text)}html[data-native=true] .layout-header{padding-top:.5rem;padding-bottom:calc(1.25rem - 10px);padding-left:max(1.25rem,var(--safe-left));padding-right:max(1.25rem,var(--safe-right))}html[data-native=true] .layout-main{padding-top:3rem;padding-left:max(1.25rem,var(--safe-left));padding-right:max(1.25rem,var(--safe-right))}@media(max-width:480px){html[data-native=true] .layout-logo-wrap{height:1.6rem;width:1.6rem}html[data-native=true] .layout-logo{height:1.6rem;transform:scale(2.91)}html[data-native=true] .layout-brand{min-width:4.7rem}}@media(orientation:landscape)and (max-height:500px){html[data-native=true] .layout-header{padding-top:.85rem;padding-bottom:.85rem}html[data-native=true] .layout-logo-wrap{height:1.8rem;width:1.8rem}html[data-native=true] .layout-logo{height:1.8rem;transform:scale(2.6)}}@media(max-width:360px){html:not([data-native=true]) .layout-brand{min-width:5.2rem}html:not([data-native=true]) .layout-header{padding-left:max(.75rem,var(--safe-left));padding-right:max(.75rem,var(--safe-right))}html:not([data-native=true]) .layout-nav{gap:.35rem}html:not([data-native=true]) .layout-nav a{padding:.2rem .25rem;font-size:.9rem}html:not([data-native=true]) .layout-signout{padding:.2rem .3rem;font-size:.8rem}html:not([data-native=true]) .layout-main{padding-left:max(.75rem,var(--safe-left));padding-right:max(.75rem,var(--safe-right))}}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.page-header h1{margin:0;font-size:1.5rem;font-weight:600}.muted{color:var(--muted);margin:0}.layout-main-settings{padding-top:3.5rem!important}html[data-native=true] .layout-main-settings{padding-top:3rem!important}.layout-outlet{flex:1;min-height:0}@media(prefers-reduced-motion:no-preference){.layout-outlet{animation:layout-fade-in .25s ease-out}}@keyframes layout-fade-in{0%{opacity:0}to{opacity:1}}.offline-banner{padding:.5rem 1rem;font-size:.9rem;background:var(--color-bg-muted, #f0f0f0);color:var(--color-text-secondary, #555)}html[data-theme=dark] .offline-banner{background:var(--color-bg-muted, #2a2a2a);color:var(--color-text-secondary, #aaa)}.settings-section{margin-top:1.5rem}.settings-section h2{font-size:1.1rem;margin:0 0 .5rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.settings-theme{display:flex;flex-wrap:wrap;gap:1rem;border:none;padding:0;margin:0}.settings-theme legend{width:100%;margin-bottom:.25rem}.settings-radio{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.95rem}.settings-radio input{width:1rem;height:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:.5rem 1rem;border-radius:8px;font-weight:500;text-decoration:none;border:1px solid transparent;cursor:pointer;font-size:.9rem;transition:filter .15s ease,background-color .15s ease,border-color .15s ease}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}a:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn-primary{background:var(--primary);color:var(--primary-contrast)}.btn-primary:hover{filter:brightness(1.05)}.btn-secondary{background:var(--surface);border-color:var(--border);color:var(--text)}.btn-secondary:hover{background:var(--hover)}.btn-sm{min-height:36px;padding:.35rem .75rem;font-size:.85rem}.btn-danger{background:var(--error-bg);color:var(--error);border-color:var(--error)}.btn-danger:hover{filter:brightness(1.1)}.btn-link{background:none;border:none;color:var(--link);padding:0;font-family:inherit;font-size:inherit;cursor:pointer;text-decoration:underline}.btn-link:hover{text-decoration:none}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:12rem}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100%;padding:max(1rem,var(--safe-top)) max(1rem,var(--safe-right)) max(1rem,var(--safe-bottom)) max(1rem,var(--safe-left))}.auth-card{width:100%;max-width:22rem;padding:1.5rem;border:1px solid var(--border);border-radius:12px;background:var(--surface)}.auth-card h1{margin:0 0 1.25rem;font-size:1.35rem}.auth-card form{display:flex;flex-direction:column;gap:1rem}.auth-card label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.auth-card input{padding:.5rem .75rem;border:1px solid var(--input-border);border-radius:6px;font-size:1rem;background:var(--bg);color:var(--text)}.auth-card input:focus{outline:2px solid var(--primary);outline-offset:2px}.auth-card button{margin-top:.25rem;padding:.6rem 1rem;border-radius:8px;font-weight:500;background:var(--primary);color:var(--primary-contrast);border:none;cursor:pointer}.auth-card button:disabled{opacity:.7;cursor:not-allowed}.auth-error{margin:0;padding:.5rem .75rem;background:var(--error-bg);color:var(--error);border-radius:6px;font-size:.9rem}.auth-message{margin:0 0 1rem;font-size:.95rem;color:var(--muted);line-height:1.45}.auth-footer{margin:1rem 0 0;font-size:.9rem;color:var(--muted)}.auth-footer-small{margin:.5rem 0 0}.auth-footer a{color:var(--link)}.upload-zone{border:2px dashed var(--border);border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}.upload-zone:hover:not(.upload-zone-disabled){border-color:var(--link);background:var(--hover)}.upload-zone-active{border-color:var(--primary);background:var(--hover)}.upload-zone-disabled{cursor:not-allowed;opacity:.8}.upload-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.upload-snap-btn{margin-top:1rem;width:100%}.upload-summary-cards{margin-top:1.5rem}.camera-preview{border:2px dashed var(--border);border-radius:12px;overflow:hidden;background:#000}.camera-preview video{display:block;width:100%;max-height:60vh;object-fit:contain}.preview-frame{margin-top:1rem;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:var(--surface);height:clamp(55vh,72vh,82vh)}.preview-iframe{width:100%;height:100%;border:0;background:var(--surface)}.preview-image{display:block;width:100%;height:100%;object-fit:contain;background:var(--bg)}.preview-zoom-host{width:100%;height:100%;overflow:hidden;display:flex;align-items:center;justify-content:center;touch-action:none;background:var(--bg)}.preview-zoom-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transform-origin:center center;will-change:transform;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.preview-pdf-zoom-host .preview-pdf-status{margin:0;align-self:center}.preview-pdf-zoom-inner{display:flex;flex-direction:column;align-items:center;transform-origin:center center;will-change:transform}.preview-pdf-canvas{display:block;max-width:none}.preview-pdf-page-gap{height:.75rem;flex-shrink:0}.preview-pdf-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:1rem;text-align:center}.preview-unknown{padding:1rem}.camera-actions{display:flex;gap:1rem;justify-content:center;padding:1rem;background:var(--surface)}.page-header-actions{display:flex;align-items:center;gap:.5rem}.dashboard-hint{margin:0 0 1rem;font-size:.95rem}.dashboard-hint a{font-weight:600}.dashboard-summary{margin-bottom:1.25rem}.metric-card{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;padding:1rem 1.25rem;border-radius:12px;background:var(--surface);border:1px solid var(--border);width:100%}.metric-card-main{flex:1;min-width:0}.metric-label{margin:0 0 .25rem;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.metric-value{margin:0;font-size:1.5rem;font-weight:600;line-height:1.2}.metric-value-loading{color:var(--muted);font-weight:500}.metric-subtext{margin:.25rem 0 0;font-size:.9rem;color:var(--muted)}.metric-progress{margin-top:.5rem;height:.9rem;border-radius:999px;background:var(--border);overflow:hidden}.metric-progress-bar{height:100%;border-radius:inherit;background:var(--progress-success)}.metric-card-side{flex-shrink:0}.metric-card-side .dashboard-filter{font-size:.9rem}.dashboard-renewals-widget{margin-bottom:1.5rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:8px}.dashboard-renewals-heading{margin:0 0 .75rem;font-size:1rem;font-weight:600}.dashboard-renewals-list{list-style:none;margin:0 0 .75rem;padding:0}.dashboard-renewals-item{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding:.35rem 0;text-decoration:none;color:var(--text);border-bottom:1px solid var(--border)}.dashboard-renewals-item:last-child{border-bottom:none}.dashboard-renewals-item:hover{color:var(--primary)}.dashboard-renewals-name{font-weight:500}.dashboard-renewals-due{font-size:.9rem;color:var(--muted)}.dashboard-filter select{padding:.35rem .5rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.9rem}.dashboard-export{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.renewals-toolbar{margin:.5rem 0 1rem}.renewals-sort-label{display:inline-flex;align-items:center;gap:.35rem;font-size:.95rem}.renewals-sort-label select{padding:.25rem .5rem;border-radius:4px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:.9rem}.renewals-sort-label input[type=text]{padding:.25rem .5rem;border-radius:4px;border:1px solid var(--border);color:var(--text);font-size:.9rem;background:#fff}[data-theme=dark] .renewals-sort-label input[type=text]{background:#333}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .renewals-sort-label input[type=text]{background:#333}}.renewals-export-label{font-size:.95rem;margin-right:.5rem}.renewals-export-hint{font-size:.9rem}.checkbox-label{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9rem}.export-success{margin:0 0 1rem;padding:.75rem 1rem;background:var(--hover);border-radius:8px;font-size:.95rem;animation:bannerFadeIn .22s cubic-bezier(.33,1,.68,1)}.export-success a{margin-right:.5rem}.cert-list{list-style:none;margin:0;padding:0}.cert-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.cert-item-check{flex-shrink:0;cursor:pointer}.cert-item-check input{width:1.1rem;height:1.1rem}.cert-item-main{flex:1;min-width:0}.cert-item-title{display:block;font-weight:500;margin-bottom:.25rem}.cert-item-meta{font-size:.9rem;color:var(--muted)}.cert-confidence{font-size:.85rem}.cert-item-actions{display:flex;gap:.5rem}.summary-card{--card-bg: var(--surface);--card-radius: 12px;--card-shadow: 0 2px 12px rgba(0, 0, 0, .06);background:var(--card-bg);border:1px solid var(--border);border-radius:var(--card-radius);box-shadow:var(--card-shadow);margin-bottom:1.25rem;overflow:hidden}[data-theme=dark] .summary-card,[data-theme=dark] .metric-card{box-shadow:0 2px 16px #0003}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .summary-card,:root:not([data-theme=light]) .metric-card{box-shadow:0 2px 16px #0003}}.summary-card-header{display:flex;align-items:center;gap:.5rem 1rem;flex-wrap:wrap;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.summary-card-title{margin:0;font-size:1rem;font-weight:600}.summary-card-count{font-size:.875rem;color:var(--muted);background:var(--hover);padding:.2rem .5rem;border-radius:999px;font-weight:500}.summary-card-view-all{margin-left:auto;font-size:.9rem;font-weight:500;color:var(--link);text-decoration:none}.summary-card-view-all:hover{text-decoration:underline}.summary-card-body{max-height:min(50vh,320px);overflow-y:auto;-webkit-overflow-scrolling:touch}.summary-card-body .cert-list,.summary-card-body .renewals-list{padding-left:1.25rem;padding-right:1.25rem}.summary-card-body .cert-list li,.summary-card-body .renewals-list li{margin:0;padding:0;list-style:none}.summary-card-empty{padding:1.25rem;text-align:center;color:var(--muted);font-size:.9rem}.summary-card-empty p{margin:0 0 .75rem}.summary-card-empty .btn{margin-top:.25rem}.summary-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.25rem;cursor:pointer;border-bottom:1px solid var(--border);transition:background-color .15s ease,box-shadow .15s ease;text-align:left;width:100%;font:inherit;color:inherit;background:transparent}.summary-row:last-child{border-bottom:none}.summary-row:hover,.summary-row:active{background:var(--hover)}.summary-row:focus{outline:2px solid var(--primary);outline-offset:-2px}.summary-row-icon{flex-shrink:0;font-size:1.25rem;line-height:1}.summary-row-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.summary-row-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-row-meta{font-size:.875rem;color:var(--muted);display:grid;align-items:center;gap:0 .5rem}.summary-row-meta-cert{grid-template-columns:5.5rem 4.25rem minmax(0,auto)}.summary-row-meta-date,.summary-row-meta-hours{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-row-meta-renewal{grid-template-columns:9.75rem minmax(0,auto)}.summary-row-meta-due{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-row-badge{font-size:.75rem;padding:.15rem .5rem;border-radius:999px;font-weight:500;justify-self:start}.summary-row-badge-confirmed{background:#22c55e26;color:#16a34a}.summary-row-badge-needs_review{background:#f59e0b33;color:#d97706}.summary-row-badge-processing,.summary-row-badge-uploaded{background:var(--hover);color:var(--muted)}.summary-row-badge-failed{background:var(--error-bg);color:var(--error)}.summary-row-check{flex-shrink:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:.5rem;margin:-.25rem .5rem -.25rem -.25rem}.summary-row-check input{width:1.1rem;height:1.1rem;cursor:pointer}.summary-row-actions{flex-shrink:0;display:flex;align-items:center;gap:.5rem;margin-left:auto}.summary-row-with-actions .summary-row-actions .btn{white-space:nowrap}.summary-row-meta-row{display:flex;flex-direction:row;align-items:center;gap:.5rem;flex-wrap:wrap}.summary-row-meta-row .summary-row-meta{min-width:0}.renewals-intro{margin-top:-.5rem;margin-bottom:1rem}.renewals-form-card{padding:1rem 1.25rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);margin-bottom:1.5rem}.renewals-form-title{margin:0 0 .75rem;font-size:1rem}.renewals-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem;margin-bottom:1rem}.renewals-form-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.renewals-form-grid input{padding:.5rem .75rem;border:1px solid var(--input-border);border-radius:6px;font-size:1rem;background:var(--bg);color:var(--text)}.field-hint{font-size:.8rem;color:var(--muted)}.renewals-form-actions{display:flex;gap:.5rem}.renewals-form-inline{margin-bottom:0}.renewals-list{list-style:none;margin:0;padding:0}.renewal-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 0;border-bottom:1px solid var(--border);flex-wrap:wrap}.renewal-item-main{flex:1;min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem}.renewal-item-name{font-weight:500}.renewal-item-category{font-size:.9rem;color:var(--muted)}.renewal-item-due{font-size:.9rem}.renewal-status{font-size:.8rem;padding:.2rem .7rem;border-radius:999px;font-weight:500;justify-self:start}.renewal-status-current{background:#22c55e26;color:#16a34a}.renewal-status-due_soon{background:#f59e0b33;color:#d97706}.renewal-status-overdue{background:var(--error-bg);color:var(--error)}.renewal-item-interval{font-size:.85rem;color:var(--muted)}.renewal-item-cert-link{font-size:.9rem}.renewal-item-check{flex-shrink:0;cursor:pointer}.renewal-item-check:has(input:disabled){cursor:default}.renewal-item-check input{width:1.1rem;height:1.1rem}.renewal-item-actions{display:flex;gap:.5rem}@media(max-width:640px){.metric-card{flex-direction:column;align-items:flex-start}}@media(max-width:640px){.renewals-form-grid{grid-template-columns:1fr}}@media(max-width:640px){.summary-card-body .cert-list,.summary-card-body .renewals-list{padding-left:.75rem;padding-right:.75rem}.certificate-summary-row,.renewal-summary-row{flex-wrap:wrap;align-items:flex-start;padding-left:.75rem;padding-right:.75rem}.certificate-summary-row .summary-row-content,.renewal-summary-row .summary-row-content{flex:1;min-width:0}.certificate-summary-row .summary-row-actions,.renewal-summary-row .summary-row-actions{width:100%;justify-content:flex-start;margin-left:0;margin-top:.25rem}.certificate-summary-row .summary-row-meta-cert{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .5rem}.certificate-summary-row .summary-row-meta-date,.certificate-summary-row .summary-row-meta-hours{flex-shrink:0}.certificate-summary-row .summary-row-badge{margin-left:auto}.renewal-summary-row .summary-row-meta-renewal{grid-template-columns:minmax(0,1fr) auto}.renewal-summary-row .summary-row-meta-due{grid-column:1 / 2}.renewal-summary-row .renewal-status{grid-column:2 / 3;justify-self:flex-end}.certificate-summary-row .summary-row-title,.renewal-summary-row .summary-row-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}}@media(prefers-reduced-motion:no-preference){html[data-native=true] .summary-row{transition:background-color .15s ease,box-shadow .15s ease,transform .1s ease}html[data-native=true] .summary-row:active{transform:scale(.995)}}.cert-duplicate-warning{padding:.75rem 1rem;background:#fef3c7;color:#92400e;border-radius:8px;margin-bottom:1rem;border:1px solid #f59e0b}.cert-duplicate-warning a{color:#b45309;font-weight:600}.cert-duplicate-delete-link{background:none;border:none;padding:0;font:inherit;color:#b45309;font-weight:700;text-decoration:underline;cursor:pointer}.cert-duplicate-delete-link:hover{color:#92400e}.cert-duplicate-suggest-delete{background:#fee2e2;color:#991b1b;border-color:#dc2626}.cert-duplicate-suggest-delete a{color:#b91c1c}.cert-duplicate-suggest-delete .cert-duplicate-delete-link{color:#dc2626;text-decoration:underline}.cert-duplicate-suggest-delete .cert-duplicate-delete-link:hover{color:#991b1b}@keyframes certCelebrationIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes certCelebrationCheckCircle{to{stroke-dashoffset:0}}@keyframes certCelebrationCheckPath{to{stroke-dashoffset:0}}.cert-celebration{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#000000a6;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:certCelebrationIn .4s ease-out}.cert-celebration-card{position:relative;padding:1.75rem 2.25rem;border-radius:12px;background:var(--surface);box-shadow:0 18px 45px #00000059;text-align:center;max-width:26rem;width:calc(100% - 3rem)}.cert-celebration-card-hours{padding:2.25rem 2.5rem;max-width:30rem}.cert-celebration-phase-check{display:flex;flex-direction:column;align-items:center;gap:1rem}.cert-celebration-hours{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;animation:certCelebrationHoursIn .4s ease-out}.cert-celebration-hours-number{font-size:clamp(2rem,6vw,4rem);font-weight:700;color:var(--text);line-height:1.2;text-shadow:0 2px 4px rgba(0,0,0,.2)}.cert-celebration-hours .cert-celebration-hours-label{margin:0;font-size:1.25rem;font-weight:500;color:var(--text);opacity:.95}@keyframes certCelebrationHoursIn{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:reduce){.cert-celebration,.cert-celebration-hours,.cert-celebration-circle,.cert-celebration-check-path{animation:none}}.cert-celebration-check{width:80px;height:80px}.cert-celebration-check-svg{width:100%;height:100%}.cert-celebration-circle{stroke:#059669;stroke-width:2;stroke-dasharray:166;stroke-dashoffset:166;animation:certCelebrationCheckCircle .5s ease-out .2s forwards}.cert-celebration-check-path{stroke:#059669;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:certCelebrationCheckPath .35s ease-out .55s forwards}.cert-celebration-message{margin:0;font-size:1.5rem;font-weight:600;color:var(--text);text-shadow:0 1px 2px rgba(0,0,0,.2)}.cert-celebration-total{margin:.5rem 0 0;font-size:1rem;font-weight:500;color:var(--text);opacity:.9}.cert-banner{padding:.75rem 1rem;background:var(--error-bg);color:var(--error);border-radius:8px;margin-bottom:1rem;font-size:.9rem}.cert-form{display:flex;flex-direction:column;gap:1rem;max-width:24rem;margin-bottom:1rem}.cert-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem}.cert-form input{padding:.5rem .75rem;border:1px solid var(--input-border);border-radius:6px;font-size:1rem;background:var(--bg);color:var(--text)}.cert-renewal-summary{margin-bottom:1rem}.cert-renewal-summary .cert-renew-by{margin-bottom:.5rem}.cert-renew-by{margin:-.25rem 0 0;font-size:.9rem;color:var(--muted)}.cert-form-actions{display:flex;gap:.75rem;flex-wrap:wrap}.cert-meta{font-size:.85rem;margin-top:1rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:max(1rem,var(--safe-top)) max(1rem,var(--safe-right)) max(1rem,var(--safe-bottom)) max(1rem,var(--safe-left))}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;max-width:24rem;width:100%;opacity:0;transform:translateY(8px) scale(.98);animation:modalFadeIn .26s cubic-bezier(.33,1,.68,1) forwards}.modal-card h2{margin:0 0 .75rem;font-size:1.25rem}.modal-card p{margin:0 0 1rem}.disclaimer-content p{margin:0 0 .75rem;font-size:.95rem;line-height:1.5}.disclaimer-content p:last-child{margin-bottom:0}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;flex-wrap:wrap}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bannerFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.modal-card{animation:none;opacity:1;transform:none}.export-success{animation:none}}.first-tour-modal{max-width:28rem}.first-tour-intro{margin:0 0 .75rem;font-size:.95rem;color:var(--muted)}.first-tour-list{margin:0 0 1.25rem;padding-left:1.25rem;font-size:.95rem;color:var(--muted);line-height:1.5}.first-tour-list li{margin-bottom:.5rem}.first-tour-list li:last-child{margin-bottom:0}.delete-all-hold{position:relative;display:block;padding:.75rem 1rem;border:2px solid var(--error);border-radius:8px;background:var(--error-bg);color:var(--error);cursor:pointer;overflow:hidden;-webkit-user-select:none;user-select:none;touch-action:none}.delete-all-hold:focus{outline:2px solid var(--error);outline-offset:2px}.delete-all-hold-progress{position:absolute;left:0;top:0;bottom:0;background:var(--error);opacity:.2;transition:width .05s linear}.delete-all-hold-label{position:relative;z-index:1;font-weight:500}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:max(1.5rem,var(--safe-top)) max(1.5rem,var(--safe-right)) max(1.5rem,var(--safe-bottom)) max(1.5rem,var(--safe-left));background:var(--bg);color:var(--text)}.error-boundary-content{max-width:24rem;text-align:center}.error-boundary-title{font-size:1.25rem;font-weight:600;margin:0 0 .5rem;color:var(--text)}.error-boundary-message{font-size:.9375rem;color:var(--muted);margin:0 0 1.25rem;line-height:1.5}.error-boundary-button{padding:.625rem 1.25rem;font-size:.9375rem;font-weight:500;color:var(--primary-contrast);background:var(--primary);border:none;border-radius:.375rem;cursor:pointer}.error-boundary-button:hover{opacity:.9}.error-boundary-button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}
