.homepage{min-height:calc(100vh - 136px);display:flex;flex-direction:column;padding:24px 0 calc(96px + env(safe-area-inset-bottom))}.homepage__section{margin-bottom:32px}.homepage__section-title{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin-bottom:16px}.homepage__actions{display:grid;gap:16px}.quick-action{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius);padding:20px;text-decoration:none;color:var(--color-text);transition:all .2s ease;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:16px;position:relative}.quick-action:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.quick-action:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.quick-action--primary{border-color:var(--color-border)}.quick-action--primary:hover{border-color:var(--color-primary)}.quick-action__content{flex:1}.quick-action__title{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin:0 0 8px}.quick-action__description{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-muted);line-height:1.5;margin:0}.quick-action__icon{width:48px;height:48px;background:var(--color-white);border:1px solid var(--color-border);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease}.quick-action__icon-svg{width:24px;height:24px;stroke:var(--color-text);transition:stroke .2s ease}.quick-action--primary .quick-action__icon{background:var(--color-primary);border-color:var(--color-primary)}.quick-action--primary .quick-action__icon-svg{stroke:var(--color-white)}.quick-action--secondary .quick-action__icon{background:var(--color-primary);border-color:var(--color-primary)}.quick-action--secondary .quick-action__icon-svg{stroke:var(--color-white)}.recent-keys{margin-top:32px}.recent-keys__title{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin-bottom:16px}.recent-keys__empty{text-align:center;padding:48px 24px;color:var(--color-muted)}.recent-keys__empty-icon{display:flex;align-items:center;justify-content:center;margin-bottom:40px}.recent-keys__brandmark{width:65px;height:80px;display:block;opacity:1}.recent-keys__empty-text{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-muted);margin:0}.recent-keys__list{display:grid;gap:12px;padding-bottom:16px}.recent-keys__item{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius);padding:16px;text-decoration:none;color:var(--color-text);display:flex;align-items:center;gap:12px;transition:all .2s ease}.recent-keys__item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.recent-keys__item-image{width:60px;height:60px;border-radius:8px;overflow:hidden;background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0}.recent-keys__item-img{width:100%;height:100%;object-fit:contain;object-position:center}.recent-keys__item-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-light-grey);color:var(--color-muted)}.recent-keys__item-placeholder svg{width:24px;height:24px}.recent-keys__item-content{flex:1}.recent-keys__item-name{font-family:var(--font-heading);font-size:16px;font-weight:600;color:var(--color-text);margin:0 0 4px;line-height:1.3}.recent-keys__item-property{font-family:var(--font-body);font-size:14px;color:var(--color-muted);margin:0;line-height:1.3}.recent-keys__item-title{font-family:var(--font-heading);font-size:var(--text-body);font-weight:600;color:var(--color-text);margin:0 0 4px}.recent-keys__item-subtitle{font-family:var(--font-body);font-size:14px;color:var(--color-muted);margin:0}:root{--scan-camera-height: 500px;--scan-hint-margin-top: 30px;--scan-hint-margin-bottom: 40px;--scan-actions-margin-top: 60px;--scan-buttons-gap: 30px;--scan-actions-padding-bottom: 32px}.scan-capture{padding:16px;display:flex;flex-direction:column;min-height:calc(100dvh - 56px);gap:16px;overflow-y:auto}.scan-capture__actions{display:flex;flex-direction:column;gap:12px;margin-top:auto;padding-top:24px;padding-bottom:24px;background:var(--color-white);position:relative}.scan-capture__actions--top{margin-top:0;padding-top:0;padding-bottom:0;background:transparent}.scan-capture__action-wrapper{position:relative;width:100%}.scan-capture__secondary-button{background:none;border:none;text-align:center;color:var(--color-primary);text-decoration:none;font-family:var(--font-body);font-size:var(--text-body);font-weight:500;cursor:pointer;transition:all .2s ease;padding:12px 24px;border-radius:8px;min-height:44px;display:flex;align-items:center;justify-content:center}.scan-capture__secondary-button:hover{color:var(--color-primary-dark);background:rgb(252,254,252)}.scan-capture__secondary-button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.scan-capture__secondary-button:active{background:rgba(0,98,9,.1);transform:translateY(1px)}.camera-placeholder{width:100%;height:var(--scan-camera-height);background:var(--color-slate-900);border-radius:16px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.camera-placeholder__overlay{position:absolute;inset:16px;border:1px solid rgba(255,255,255,.2);border-radius:12px;display:flex;align-items:center;justify-content:center}.camera-placeholder__icon{width:80px;height:80px;color:#fff;stroke:currentColor}.scan-action-selector{position:absolute;top:100%;left:0;right:0;margin-top:8px;background:var(--color-white);border-radius:12px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;padding:8px;z-index:100;display:flex;flex-direction:column;gap:4px;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.scan-action-selector__option{display:flex;align-items:center;gap:12px;padding:12px 16px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;text-align:left;font-family:var(--font-body);font-size:15px;color:var(--color-text);width:100%}.scan-action-selector__option:hover:not(:disabled){background:#f8f9fa}.scan-action-selector__option:active:not(:disabled){background:#e9ecef;transform:scale(.98)}.scan-action-selector__option:disabled{opacity:.5;cursor:not-allowed}.scan-action-selector__icon{font-size:20px;line-height:1;flex-shrink:0}.scan-action-selector__text{flex:1;font-weight:500}.scan-capture__file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.scan-capture--compact-camera{--scan-camera-height: 280px}.scan-capture--tall-camera{--scan-camera-height: 400px}.scan-capture--close-hint{--scan-hint-margin-top: 12px;--scan-hint-margin-bottom: 24px}.scan-capture--far-hint{--scan-hint-margin-top: 32px;--scan-hint-margin-bottom: 60px}.scan-capture--close-buttons{--scan-actions-margin-top: 32px;--scan-buttons-gap: 12px}.scan-capture--far-buttons{--scan-actions-margin-top: 80px;--scan-buttons-gap: 28px}:root{--review-image-height: 280px;--review-banner-to-image-gap: 20px;--review-image-to-buttons-gap: 24px;--review-actions-gap: 16px}.scan-review{padding:16px;display:flex;flex-direction:column;height:calc(100dvh - 56px);overflow:hidden}.scan-review__banner{background:#f0f9ff;border:2px solid #0ea5e9;border-radius:8px;padding:12px 16px;display:flex;align-items:center;gap:12px;margin-bottom:var(--review-banner-to-image-gap)}.scan-review__banner-icon{width:20px;height:20px;color:#0ea5e9;stroke:currentColor;flex-shrink:0}.scan-review__banner-text{font-family:var(--font-body);font-size:14px;font-weight:500;color:#0369a1;margin:0}.scan-review__content{flex:1;display:flex;flex-direction:column;margin-bottom:var(--review-image-to-buttons-gap)}.scan-review__actions{display:flex;flex-direction:column;gap:var(--review-actions-gap);padding-bottom:16px}.image-preview{width:100%;border-radius:16px;overflow:hidden;border:4px solid #000000;display:flex;align-items:center;justify-content:center;margin:0 auto;max-width:100%}.image-preview__img{display:block;width:100%;height:auto;object-fit:contain;object-position:center}.image-preview__placeholder{width:100%;min-height:var(--review-image-height);background:var(--color-slate-50);display:flex;align-items:center;justify-content:center;padding:40px 20px}.image-preview__placeholder-content{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.image-preview__placeholder-icon{width:64px;height:64px;color:#94a3b8;stroke:currentColor}.image-preview__placeholder-text{font-family:var(--font-body);font-size:14px;color:var(--color-muted);margin:0}.scan-review--compact-image{--review-image-height: 320px}.scan-review--large-image{--review-image-height: 480px}.scan-review--close-spacing{--review-banner-to-image-gap: 12px;--review-image-to-buttons-gap: 32px;--review-actions-gap: 16px}.scan-review--far-spacing{--review-banner-to-image-gap: 24px;--review-image-to-buttons-gap: 60px;--review-actions-gap: 24px}.keys-page{min-height:100vh}.keys-page__header{display:flex;justify-content:space-between;align-items:center;padding:24px 0;border-bottom:1px solid var(--color-border)}.keys-page__title{font-family:var(--font-heading);font-size:var(--text-h1);font-weight:700;color:var(--color-text)}.keys-page__add-btn{background:var(--color-primary);color:var(--color-white);border:none;border-radius:var(--radius);padding:12px 24px;font-family:var(--font-heading);font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px}.keys-page__grid{display:grid;gap:16px;padding:24px 0}.keys-page__empty{text-align:center;padding:64px 24px;color:var(--color-muted)}.keys-page__empty-icon{width:80px;height:80px;margin:0 auto 24px;color:var(--color-light-grey)}.keys-page__empty-title{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin-bottom:8px}.keys-page__empty-text{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-muted);margin-bottom:24px}.key-detail{min-height:100vh}.key-detail__header{padding:24px 0;border-bottom:1px solid var(--color-border)}.key-detail__image{width:100%;max-width:300px;aspect-ratio:1;object-fit:contain;border-radius:var(--radius);margin:0 auto 24px;display:block}.key-detail__title{font-family:var(--font-heading);font-size:var(--text-h1);font-weight:700;color:var(--color-text);text-align:center;margin-bottom:8px}.key-detail__subtitle{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-muted);text-align:center;margin-bottom:32px}.key-detail__content{padding:24px 0}.key-detail__section{margin-bottom:32px}.key-detail__section-title{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin-bottom:16px}.key-detail__form{display:grid;gap:16px}.key-detail__actions{display:flex;gap:12px;margin-top:24px}.settings-page{min-height:100vh}.settings-page__header{padding:24px 0;border-bottom:1px solid var(--color-border)}.settings-page__title{font-family:var(--font-heading);font-size:var(--text-h1);font-weight:700;color:var(--color-text);text-align:center}.settings-page__content{padding:24px 0}.settings-page__section{margin-bottom:32px}.settings-page__section-title{font-family:var(--font-heading);font-size:var(--text-h2);font-weight:700;color:var(--color-text);margin-bottom:16px}.settings-page__list{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.settings-page__item{padding:16px;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;text-decoration:none;color:var(--color-text);transition:background-color .2s ease}.settings-page__item:last-child{border-bottom:none}.settings-page__item:hover{background:var(--color-light-grey)}.settings-page__item-text{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-text)}.settings-page__item-icon{color:var(--color-muted)}.scan-processing{padding:16px;display:flex;flex-direction:column;min-height:calc(100dvh - 56px);align-items:center;justify-content:center;text-align:center}.scan-processing__content{display:flex;flex-direction:column;align-items:center;gap:40px;max-width:400px;width:100%}.scan-processing__title{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--color-text);margin:0;line-height:1.2}.scan-processing__spinner{display:flex;align-items:center;justify-content:center}.scan-processing__spinner-circle{width:60px;height:60px;border:3px solid #e5e7eb;border-radius:50%;position:relative;overflow:hidden}.scan-processing__spinner-progress{position:absolute;top:0;left:0;width:100%;height:100%;border:3px solid transparent;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.scan-processing__steps{display:flex;flex-direction:column;gap:8px;text-align:center}.scan-processing__step{font-family:var(--font-body);font-size:16px;color:var(--color-muted);margin:0;line-height:1.5}.scan-match-found{padding:20px 16px calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column;min-height:calc(100dvh - 56px);align-items:center;justify-content:flex-start}.scan-match-found__content{display:flex;flex-direction:column;align-items:stretch;gap:20px;max-width:380px;width:100%}.scan-match-found__header{display:flex;align-items:center;justify-content:center;gap:12px}.scan-match-found__header-spacer{width:52px;flex-shrink:0}.scan-match-found__title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--color-text);margin:0;line-height:1.2}.scan-match-found__success-icon{width:52px;height:52px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.scan-match-found__success-icon svg{width:28px;height:28px}.scan-match-found__key-card{width:100%;display:flex;flex-direction:column;align-items:stretch;gap:12px}.scan-match-found__key-image{border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;border:4px solid #000000;width:100%}.scan-match-found__key-img{display:block;width:100%;height:auto;object-fit:contain;object-position:center}.scan-match-found__key-details{display:flex;flex-direction:column;gap:8px;text-align:center}.scan-match-found__key-name{font-family:var(--font-heading);font-size:18px;font-weight:700;color:var(--color-text);margin:0;line-height:1.3}.scan-match-found__key-address{font-family:var(--font-body);font-size:15px;color:var(--color-muted);margin:0;line-height:1.35}.scan-match-found__actions{display:flex;flex-direction:column;gap:12px;width:100%}.scan-no-match{padding:20px 16px calc(24px + env(safe-area-inset-bottom));display:flex;flex-direction:column;min-height:calc(100dvh - 56px);align-items:center;justify-content:flex-start}.scan-no-match__content{display:flex;flex-direction:column;align-items:stretch;gap:16px;max-width:380px;width:100%}.scan-no-match__header{display:flex;align-items:center;justify-content:center;gap:12px}.scan-no-match__header-spacer{width:52px;flex-shrink:0}.scan-no-match__title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--color-text);margin:0;line-height:1.2}.scan-no-match__no-match-icon{width:52px;height:52px;background:#ef4444;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.scan-no-match__no-match-icon svg{width:28px;height:28px}.scan-no-match__key-card{width:100%;display:flex;flex-direction:column;align-items:center;gap:10px}.scan-no-match__key-image{border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;border:4px solid #000000;width:100%;max-height:240px}.scan-no-match__key-img{display:block;width:100%;height:auto;object-fit:contain;object-position:center}.scan-no-match__message{text-align:center;margin-top:4px}.scan-no-match__message-text{font-family:var(--font-body);font-size:15px;color:var(--color-muted);margin:0;line-height:1.5}.scan-no-match__actions{display:flex;flex-direction:column;gap:12px;width:100%;padding-bottom:calc(env(safe-area-inset-bottom) + 8px)}.keys-inventory{padding:16px 16px 100px;display:flex;flex-direction:column;min-height:calc(100dvh - 56px);background:var(--color-background)}.keys-inventory__header{text-align:center;margin-bottom:24px}.keys-inventory__title{font-family:var(--font-heading);font-size:28px;font-weight:700;color:var(--color-text);margin:0;line-height:1.2}.keys-inventory__search{margin-bottom:20px}.keys-inventory__search-input{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:12px;font-family:var(--font-body);font-size:16px;background:var(--color-white);color:var(--color-text);outline:none;transition:border-color .2s ease}.keys-inventory__search-input:focus{border-color:var(--color-primary)}.keys-inventory__search-input::placeholder{color:var(--color-muted)}.keys-inventory__filters{display:flex;gap:8px;margin-bottom:24px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;-ms-overflow-style:none}.keys-inventory__filters::-webkit-scrollbar{display:none}.keys-inventory__filter-chip{background:var(--color-light-grey);border:none;border-radius:20px;padding:8px 16px;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--color-text);cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.keys-inventory__filter-chip:hover{background:#e5e7eb}.keys-inventory__filter-chip--active{background:var(--color-primary);color:var(--color-white)}.keys-inventory__filter-chip--active:hover{background:var(--color-primary-dark)}.keys-inventory__content{flex:1}.keys-inventory__list{display:flex;flex-direction:column;gap:12px}.keys-inventory__item{background:var(--color-white);border:1px solid var(--color-border);border-radius:12px;padding:16px;display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.keys-inventory__item:hover{border-color:var(--color-primary);box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.keys-inventory__item:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.keys-inventory__item-image{width:60px;height:60px;border-radius:8px;overflow:hidden;background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0}.keys-inventory__item-img{width:100%;height:100%;object-fit:contain;object-position:center}.keys-inventory__item-content{flex:1;min-width:0}.keys-inventory__item-name{font-family:var(--font-heading);font-size:16px;font-weight:700;color:var(--color-text);margin:0 0 4px;line-height:1.3}.keys-inventory__item-property{font-family:var(--font-body);font-size:14px;color:var(--color-muted);margin:0;line-height:1.4}.keys-inventory__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 24px;min-height:300px}.keys-inventory__empty-icon{width:80px;height:80px;color:var(--color-muted);margin-bottom:24px;opacity:.5}.keys-inventory__empty-icon svg{width:100%;height:100%}.keys-inventory__empty-title{font-family:var(--font-heading);font-size:20px;font-weight:700;color:var(--color-text);margin:0 0 8px;line-height:1.3}.keys-inventory__empty-text{font-family:var(--font-body);font-size:16px;color:var(--color-muted);margin:0;line-height:1.5;max-width:280px}.key-details{padding:16px;display:flex;flex-direction:column;min-height:calc(100dvh - 56px);background:var(--color-background)}.key-details__edit-button-header,.key-details__cancel-button-header{background:var(--color-primary);color:var(--color-white);border:none;border-radius:6px;padding:4px 12px;font-family:var(--font-body);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;height:auto;line-height:1.4}.key-details__edit-button-header:hover,.key-details__cancel-button-header:hover{background:var(--color-primary-dark)}.key-details__cancel-button-header{background:var(--color-muted)}.key-details__cancel-button-header:hover{background:#6b7280}.key-details__content{flex:1;display:flex;flex-direction:column;gap:32px}.key-details__image-container{display:flex;justify-content:center;margin-bottom:8px}.key-details__image{width:200px;height:200px;object-fit:contain;object-position:center;border-radius:12px;background:transparent;cursor:pointer;transition:transform .2s ease}.key-details__image:hover{transform:scale(1.02)}.key-details__photos-label{font-family:var(--font-heading);font-weight:700;font-size:var(--text-body);text-align:center;margin-bottom:8px;color:var(--color-text)}.key-details__photos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:8px;max-width:320px;margin-left:auto;margin-right:auto}.key-details__photo-slot{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;display:flex;align-items:center;justify-content:center}.key-details__photo-slot--filled{border:2px solid var(--color-primary)}.key-details__photo-slot--empty{border:2px dashed var(--color-slate-300, #cbd5e1);background:var(--color-slate-50, #f8fafc);cursor:pointer;transition:all .2s ease}.key-details__photo-slot--empty:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-slate-100, #f1f5f9)}.key-details__photo-slot--empty:disabled{opacity:.4;cursor:default}.key-details__photo-slot--uploading{border:2px solid var(--color-slate-300, #cbd5e1);background:var(--color-slate-50, #f8fafc)}.key-details__photo-thumb{width:100%;height:100%;object-fit:cover}.key-details__photo-plus{font-size:28px;color:var(--color-slate-400, #94a3b8);font-weight:300}.key-details__photo-badge{position:absolute;bottom:4px;right:4px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.key-details__photo-remove{position:absolute;top:2px;right:2px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;border:none;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}.key-details__photo-remove:hover{background:rgba(220,38,38,.8)}.key-details__photo-error{color:var(--color-error, #dc2626);font-size:13px;text-align:center;margin-bottom:4px}.key-details__photos-hint{font-size:13px;color:var(--color-text-secondary, #64748b);text-align:center;margin-bottom:12px}.image-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.image-modal__content{position:relative;max-width:90%;max-height:90%;display:flex;align-items:center;justify-content:center}.image-modal__img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 10px 25px #00000080}.image-modal__close{position:absolute;top:-40px;right:0;background:rgba(255,255,255,.9);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease}.image-modal__close:hover{background:rgba(255,255,255,1)}.image-modal__close svg{width:18px;height:18px;color:#333}.key-details__form{display:flex;flex-direction:column;gap:24px}.key-details__field{display:flex;flex-direction:column;gap:8px}.key-details__label{font-family:var(--font-body);font-size:16px;font-weight:500;color:var(--color-text);margin:0}.key-details__required{color:#ef4444;margin-left:2px}.key-details__hint{font-family:var(--font-body);font-size:14px;color:var(--color-muted);margin:0;line-height:1.4}.key-details__input,.key-details__textarea{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:12px;font-family:var(--font-body);font-size:16px;background:var(--color-white);color:var(--color-text);outline:none;transition:all .2s ease;box-sizing:border-box}.key-details__input:focus,.key-details__textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #0062091a}.key-details__input:disabled,.key-details__textarea:disabled{background:#f9fafb;color:var(--color-muted);cursor:not-allowed}.key-details__input::placeholder,.key-details__textarea::placeholder{color:var(--color-muted)}.key-details__textarea{resize:vertical;min-height:100px;line-height:1.5}.key-details__actions{display:flex;gap:12px;margin-top:32px;padding-bottom:16px}.key-details__delete-button,.key-details__save-button{flex:1}.key-details__save-button:disabled{background:#d1d5db;color:#4b5563;cursor:not-allowed}.key-details__save-button:disabled:hover{background:#d1d5db;transform:none}.key-details__save-button--full-width{flex:1}.scan-success{padding:16px;display:flex;flex-direction:column;min-height:calc(100dvh - 56px);align-items:center;justify-content:center;background:var(--color-background)}.scan-success__content{display:flex;flex-direction:column;align-items:center;gap:32px;max-width:400px;width:100%;text-align:center}.scan-success__icon{width:80px;height:80px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.scan-success__icon svg{width:40px;height:40px}.scan-success__title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--color-text);margin:0;line-height:1.3}.scan-success__subcopy{font-family:var(--font-body);font-size:16px;color:var(--color-muted);margin:0;line-height:1.5;max-width:300px}.scan-success__actions{width:100%;margin-top:16px}.scan-error{padding:16px;display:flex;flex-direction:column;min-height:calc(100dvh - 56px);align-items:center;justify-content:center;background:var(--color-background)}.scan-error__content{display:flex;flex-direction:column;align-items:center;gap:32px;max-width:400px;width:100%;text-align:center}.scan-error__icon{width:80px;height:80px;background:#ef4444;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff}.scan-error__icon svg{width:40px;height:40px}.scan-error__title{font-family:var(--font-heading);font-size:24px;font-weight:700;color:var(--color-text);margin:0;line-height:1.3}.scan-error__subcopy{font-family:var(--font-body);font-size:16px;color:var(--color-muted);margin:0;line-height:1.5;max-width:300px}.scan-error__actions{width:100%;margin-top:16px}.scan-invalid{padding:0;display:flex;flex-direction:column;min-height:calc(100dvh - 56px);background:var(--color-background)}.scan-invalid__content{display:flex;flex-direction:column;height:calc(100dvh - 56px)}.scan-invalid__image-container{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-white);border-bottom:1px solid var(--color-border);padding:20px}.scan-invalid__image{width:100%;max-width:300px;height:auto;object-fit:contain;object-position:center;filter:blur(3px);border-radius:8px}.scan-invalid__message-section{background:var(--color-white);padding:32px 24px;text-align:center;border-top:1px solid var(--color-border);box-shadow:0 -2px 8px #0000001a}.scan-invalid__message{font-family:var(--font-body);font-size:16px;color:var(--color-text);margin:0 0 24px;line-height:1.5}.scan-invalid__retake-button{width:100%;max-width:280px;margin:0 auto}.scan-new-key{min-height:100vh;display:flex;flex-direction:column;padding:24px 0 100px}.scan-new-key__content{flex:1;display:flex;flex-direction:column;max-width:400px;margin:0 auto;padding:0 24px}.scan-new-key__header{text-align:center;margin-bottom:32px}.scan-new-key__title{font-family:var(--font-heading);font-size:var(--text-h1);font-weight:700;color:var(--color-text);margin-bottom:8px}.scan-new-key__subtitle{font-size:var(--text-body);color:var(--color-text-secondary);line-height:1.5}.scan-new-key__key-preview{display:flex;flex-direction:column;align-items:center;margin-bottom:32px;padding:24px;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.scan-new-key__key-image{width:120px;height:80px;border-radius:var(--radius-sm);overflow:hidden;margin-bottom:12px;background:var(--color-gray-50);display:flex;align-items:center;justify-content:center}.scan-new-key__key-img{width:100%;height:100%;object-fit:contain}.scan-new-key__key-badge{background:var(--color-primary);color:var(--color-white);padding:4px 12px;border-radius:12px;font-size:var(--text-sm);font-weight:500}.scan-new-key__form{flex:1;display:flex;flex-direction:column}.scan-new-key__form-content{flex:1;margin-bottom:32px}.scan-new-key__field{margin-bottom:24px}.scan-new-key__label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--color-text);margin-bottom:8px}.scan-new-key__input,.scan-new-key__textarea{width:100%;padding:12px 16px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:var(--text-body);color:var(--color-text);background:var(--color-white);transition:border-color .2s ease}.scan-new-key__input:focus,.scan-new-key__textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0062091a}.scan-new-key__textarea{resize:vertical;min-height:80px}.scan-new-key__actions{display:grid;grid-template-columns:1fr 1fr;gap:12px}.scan-new-key__errors{display:flex;align-items:flex-start;gap:12px;padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius);margin-bottom:24px}.scan-new-key__error-icon{flex-shrink:0;color:#dc2626;margin-top:2px}.scan-new-key__error-content{flex:1}.scan-new-key__error-title{font-size:var(--text-sm);font-weight:500;color:#dc2626;margin-bottom:8px}.scan-new-key__error-list{list-style:none;padding:0;margin:0}.scan-new-key__error-item{font-size:var(--text-sm);color:#dc2626;margin-bottom:4px}.scan-new-key__error-item:last-child{margin-bottom:0}.key-type-selector{display:flex;flex-direction:column;gap:20px;padding:8px 0}.key-type-selector__subtitle{font-family:var(--font-body);font-size:var(--text-body);color:var(--color-muted);text-align:center}.key-type-selector__grid{display:flex;flex-direction:column;gap:12px}.key-type-selector__option{display:flex;align-items:center;gap:16px;padding:16px;background:var(--color-white);border:2px solid var(--color-border);border-radius:12px;cursor:pointer;transition:border-color .15s,background .15s;text-align:left;width:100%}.key-type-selector__option:hover,.key-type-selector__option:focus{border-color:var(--color-primary);background:#f0fdf0}.key-type-selector__option:active{background:#dcfce7}.key-type-selector__option--auto{border-style:dashed}.key-type-selector__option-icon{width:56px;height:32px;flex-shrink:0;color:var(--color-primary)}.key-type-selector__option-icon svg{width:100%;height:100%}.key-type-selector__option-icon--auto{width:32px;height:32px;color:var(--color-muted)}.key-type-selector__option-info{flex:1;display:flex;flex-direction:column;gap:2px}.key-type-selector__option-label{font-family:var(--font-heading);font-size:var(--text-body);font-weight:700;color:var(--color-text)}.key-type-selector__option-description{font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-muted)}.key-type-selector__option-arrow{width:20px;height:20px;flex-shrink:0;color:var(--color-muted)}.scan-bitting-results{background:var(--color-white);border:1px solid var(--color-border);border-radius:12px;padding:16px;margin:0 0 8px}.scan-bitting-results__code{text-align:center;margin-bottom:12px}.scan-bitting-results__label{font-family:var(--font-body);font-size:var(--text-sm);color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:8px}.scan-bitting-results__digits{display:flex;gap:8px;justify-content:center}.scan-bitting-results__digit{width:40px;height:48px;display:flex;align-items:center;justify-content:center;font-family:Courier New,monospace;font-size:24px;font-weight:700;background:#f1f5f9;border-radius:8px;color:var(--color-text)}.scan-bitting-results__meta{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.scan-bitting-results__tag{font-family:var(--font-heading);font-size:var(--text-sm);font-weight:700;color:var(--color-primary);background:#dcfce7;padding:2px 10px;border-radius:999px}.scan-bitting-results__quality{font-family:var(--font-body);font-size:var(--text-sm);font-weight:500}.scan-bitting-results__quality--high{color:#16a34a}.scan-bitting-results__quality--medium{color:#d97706}.scan-bitting-results__quality--low{color:#dc2626}.scan-bitting-results__method{font-family:var(--font-body);font-size:var(--text-caption);color:var(--color-muted)}.camera-guide{flex:1;display:flex;flex-direction:column;gap:16px}.camera-guide__frame{background:#0f172a;border-radius:16px;aspect-ratio:3 / 1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:24px}.camera-guide__silhouette{width:80%;height:auto;opacity:.5}.camera-guide__instruction{color:#ffffffd9;font-family:var(--font-body);font-size:14px;font-weight:500;text-align:center;margin-top:12px}.camera-guide__tips{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.camera-guide__tip{font-family:var(--font-body);font-size:13px;color:var(--color-muted);font-weight:500}.camera-guide__tip-divider{width:4px;height:4px;border-radius:50%;background:var(--color-border)}.scan-review__key-type-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-heading);font-size:var(--text-sm);font-weight:700;color:var(--color-primary);background:#dcfce7;padding:4px 12px;border-radius:999px;margin-top:8px}.scan-capture--webrtc{position:fixed;inset:0;z-index:100;background:#000;padding:0}.webrtc-camera{position:relative;width:100%;height:100%;overflow:hidden;background:#000}.webrtc-camera__video{width:100%;height:100%;object-fit:cover}.webrtc-camera__flash{position:absolute;inset:0;background:#fff;opacity:.8;pointer-events:none;animation:flash-fade .15s ease-out forwards}@keyframes flash-fade{0%{opacity:.8}to{opacity:0}}.webrtc-camera__overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:400px;display:flex;flex-direction:column;align-items:center;pointer-events:none}.webrtc-camera__silhouette{width:100%;height:auto;filter:drop-shadow(0 0 8px rgba(0,0,0,.5))}.webrtc-camera__hint{color:#ffffffd9;font-family:var(--font-body);font-size:14px;font-weight:500;text-align:center;margin-top:12px;text-shadow:0 1px 4px rgba(0,0,0,.6)}.webrtc-camera__counter{position:absolute;top:16px;right:16px;background:rgba(0,0,0,.6);color:#fff;font-family:var(--font-body);font-size:14px;font-weight:600;padding:6px 14px;border-radius:999px;backdrop-filter:blur(4px)}.webrtc-camera__previews{position:absolute;bottom:110px;left:0;right:0;display:flex;justify-content:center;gap:8px;padding:0 16px}.webrtc-camera__preview-item{position:relative;width:52px;height:52px;border-radius:8px;overflow:hidden;border:2px solid rgba(255,255,255,.7);flex-shrink:0}.webrtc-camera__preview-item img{width:100%;height:100%;object-fit:cover}.webrtc-camera__preview-remove{position:absolute;top:-2px;right:-2px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.7);color:#fff;border:none;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.webrtc-camera__controls{position:absolute;bottom:24px;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:24px;padding:0 24px;padding-bottom:env(safe-area-inset-bottom)}.webrtc-camera__capture-btn{width:72px;height:72px;border-radius:50%;border:4px solid #fff;background:transparent;padding:4px;cursor:pointer;flex-shrink:0}.webrtc-camera__capture-btn:active{transform:scale(.92)}.webrtc-camera__capture-btn-inner{display:block;width:100%;height:100%;border-radius:50%;background:#fff}.webrtc-camera__capture-btn:disabled{opacity:.4;cursor:default}.webrtc-camera__done-btn{background:var(--color-primary, #16a34a);color:#fff;border:none;border-radius:999px;padding:12px 28px;font-family:var(--font-heading);font-size:16px;font-weight:700;cursor:pointer;white-space:nowrap}.webrtc-camera__done-btn:active{transform:scale(.96)}.webrtc-camera__back-btn{position:absolute;top:16px;left:16px;z-index:101;background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:8px;padding:8px 16px;font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;backdrop-filter:blur(4px)}.webrtc-camera__uploading{position:absolute;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:10}.webrtc-camera__uploading p{color:#fff;font-family:var(--font-heading);font-size:18px;font-weight:600}.webrtc-camera__error{position:absolute;bottom:100px;left:16px;right:16px;text-align:center;color:#fca5a5;font-family:var(--font-body);font-size:14px;font-weight:500}.webrtc-camera__loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}.webrtc-camera__loading p{color:#ffffffb3;font-family:var(--font-body);font-size:16px}
