:root{--color-bg: #0c0e12;--color-surface: #161820;--color-surface-raised: #1e2030;--color-border: #262840;--color-glow: rgba(220, 120, 50, .3);--color-text: #e8e4d8;--color-text-muted: #7878a0;--color-primary: #dc7832;--color-primary-hover: #c46828;--color-primary-text: #0c0e12;--color-danger: #c44040;--color-danger-hover: #a83030;--color-success: #4caf6c;--bg: var(--color-bg);--surface: var(--color-surface);--surface-raised: var(--color-surface-raised);--border: var(--color-border);--glow: var(--color-glow);--text: var(--color-text);--text-muted: var(--color-text-muted);--primary: var(--color-primary);--primary-hover: var(--color-primary-hover);--primary-text: var(--color-primary-text);--danger: var(--color-danger);--danger-hover: var(--color-danger-hover);--success: var(--color-success);--radius: 6px;--radius-lg: 10px;--transition: .12s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{min-height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--color-bg);color:var(--color-text);font-size:15px;line-height:1.5}#root{height:100%}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:56px;background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;position:sticky;top:0;z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.nav-brand{display:flex;align-items:center;gap:1.5rem}.brand{font-weight:700;font-size:1.1rem;letter-spacing:-.02em;color:var(--color-primary)}.nav-link{color:var(--color-text-muted);text-decoration:none;font-size:.9rem;transition:color var(--transition)}.nav-link:hover,.nav-link.active{color:var(--color-text)}.nav-link.active{color:var(--color-primary)}.nav-user{display:flex;align-items:center;gap:.5rem}.user-name-btn{font-size:.85rem;color:var(--color-text-muted)}.app-main{flex:1;padding:1.5rem;max-width:960px;margin:0 auto;width:100%}.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;cursor:pointer;border:1px solid transparent;transition:background var(--transition),color var(--transition),box-shadow var(--transition);white-space:nowrap}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--color-primary);color:var(--color-primary-text)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 0 12px var(--color-glow)}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){color:var(--color-text);border-color:var(--color-primary)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover)}.btn-secondary{background:var(--color-surface-raised);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){border-color:var(--color-primary)}.btn-danger-ghost{color:var(--color-danger)}.btn-danger-ghost:hover:not(:disabled){color:var(--color-danger);border-color:var(--color-danger)}.btn-danger-outline{background:transparent;color:var(--color-danger);border:1px solid var(--color-danger)}.btn-danger-outline:hover:not(:disabled){background:var(--color-danger);color:#fff}.btn-sm{padding:.3rem .65rem;font-size:.8rem}.signin-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg)}.signin-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2.5rem;max-width:380px;width:100%;text-align:center;box-shadow:0 0 40px #dc783214}.signin-logo{font-size:3rem;margin-bottom:.5rem}.signin-card h1{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:.25rem;letter-spacing:-.03em}.signin-tagline{color:var(--color-text-muted);font-size:.9rem;margin-bottom:1rem}.signin-joke{color:var(--color-text-muted);font-size:.85rem;font-style:italic;margin-bottom:1.5rem;padding:.75rem;background:var(--color-surface-raised);border-radius:var(--radius);border-left:3px solid var(--color-primary)}.gear-table{width:100%;border-collapse:collapse;font-size:.88rem}.gear-table th{text-align:left;padding:.4rem .6rem;border-bottom:2px solid var(--color-border);color:var(--color-text-muted);font-weight:600;white-space:nowrap}.gear-table td{padding:.45rem .6rem;border-bottom:1px solid var(--color-border);vertical-align:middle}.gear-table-num{text-align:right!important;white-space:nowrap}.gear-table-cat{color:var(--color-text-muted);white-space:nowrap}.gear-table-actions{width:2rem}.gear-table-row{cursor:pointer;transition:background .1s}.gear-table-row:hover{background:var(--color-surface-raised)}.gear-table-name{font-weight:500}.gear-table-brand{color:var(--color-text-muted);margin-left:.4rem;font-size:.83em}.gear-table-tags{display:block;color:var(--color-text-muted);font-size:.78em;margin-top:.1rem}.gear-table tfoot td{border-top:2px solid var(--color-border);border-bottom:none;font-weight:600;padding-top:.5rem}.gear-page{display:flex;flex-direction:column;gap:1.5rem}.gear-summary{display:block;font-size:.85rem;color:var(--color-text-muted);margin-top:.2rem}.gear-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.gear-header h2{font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.gear-joke{display:block;font-size:.82rem;color:var(--color-text-muted);font-style:italic;margin-top:.2rem}.gear-header-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}@media(max-width:600px){.gear-header{flex-direction:column;align-items:stretch}.gear-header-actions{justify-content:flex-start}.gear-header-actions .btn{padding:.3rem .5rem;font-size:.78rem}}.gear-filters{display:flex;flex-wrap:wrap;gap:.5rem}.gear-search{flex:1;min-width:180px;padding:.45rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.875rem;transition:border-color var(--transition)}.gear-search:focus{outline:none;border-color:var(--color-primary)}.gear-cat-filter,.gear-filter-select{padding:.45rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.875rem;cursor:pointer;transition:border-color var(--transition)}.gear-cat-filter:focus,.gear-filter-select:focus{outline:none;border-color:var(--color-primary)}.filter-dropdown,.filter-btn{position:relative}.filter-btn--active{color:var(--color-primary)!important;border-color:var(--color-primary)!important}.filter-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:var(--color-primary);color:var(--color-primary-text);font-size:.65rem;font-weight:700;line-height:1}.filter-panel{position:absolute;top:calc(100% + 6px);left:0;z-index:20;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.75rem 1rem;min-width:220px;box-shadow:0 8px 32px #00000080}.filter-section{margin-bottom:.4rem}.filter-section-label{color:var(--color-text-muted);font-size:.8rem;font-weight:600}.filter-divider{border:none;border-top:1px solid var(--color-border);margin:.4rem 0}.filter-clear-btn{width:100%;justify-content:center;margin-top:.2rem}.category-group{display:flex;flex-direction:column;gap:.75rem}.category-header{display:flex;align-items:baseline;gap:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.category-name{font-size:1rem;font-weight:600;color:var(--color-text)}.uncategorized-header{flex-direction:column;align-items:flex-start}.uncategorized-hint{font-size:.8rem;color:var(--color-text-muted)}.gear-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.gear-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.9rem;display:flex;flex-direction:column;gap:.5rem;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition)}.gear-card:hover{border-color:var(--color-primary);box-shadow:0 0 10px var(--color-glow);transform:translateY(-2px)}.gear-card--selectable{cursor:pointer}.gear-card--selected{border-color:var(--color-primary);background:#dc78320d}.gear-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.gear-card-select-label{display:flex;align-items:center;gap:.5rem;flex:1;cursor:pointer}.gear-card-checkbox{width:16px;height:16px;flex-shrink:0;accent-color:var(--color-primary)}.gear-name{font-weight:600;font-size:.9rem;line-height:1.3}.gear-brand{font-size:.8rem;color:var(--color-text-muted)}.gear-desc{font-size:.82rem;color:var(--color-text-muted);line-height:1.5}.gear-card-actions{display:flex;gap:.1rem;flex-shrink:0}.gear-stats{display:flex;flex-wrap:wrap;gap:.3rem}.gear-stat{font-size:.75rem;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:999px;padding:.1rem .5rem;color:var(--color-primary);font-variant-numeric:tabular-nums}.gear-shared-badge{font-size:.75rem;background:#dc783214;border:1px solid rgba(220,120,50,.2);border-radius:999px;padding:.1rem .5rem;color:var(--color-text-muted)}.gear-tags{display:flex;flex-wrap:wrap;gap:.3rem}.gear-tag{font-size:.72rem;background:#dc78321a;border:1px solid rgba(220,120,50,.25);border-radius:20px;padding:.1rem .5rem;color:var(--color-primary)}.gear-link{font-size:.78rem;color:var(--color-text-muted);text-decoration:none;align-self:flex-start;transition:color var(--transition)}.gear-link:hover{color:var(--color-primary)}.gear-no-results{color:var(--color-text-muted);font-style:italic;padding:2rem 0}.gear-empty{text-align:center;padding:5rem 2rem;border:1px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted)}.gear-empty-icon{font-size:2.5rem;margin-bottom:1rem}.gear-empty h3{font-size:1.1rem;color:var(--color-text);margin-bottom:.5rem}.page-loader,.page-error{padding:3rem;text-align:center;color:var(--color-text-muted)}.page-summary-frame{display:flex;flex-direction:column;gap:.35rem;padding:1rem 1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-lg)}.page-summary-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-primary);display:block;margin-bottom:.2rem}.page-summary-stats{font-size:.82rem;color:var(--color-text-muted);display:block;margin-bottom:.5rem}.page-summary-text{font-size:.875rem;color:var(--color-text);line-height:1.6}.catch-log-page{display:flex;flex-direction:column;gap:1.5rem}.catch-stats{display:flex;flex-wrap:wrap;gap:.75rem}.catch-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:.85rem 1.1rem;display:flex;flex-direction:column;gap:.15rem;min-width:140px;border-left:3px solid var(--color-primary)}.catch-stat-value{font-size:1.25rem;font-weight:700;color:var(--color-primary);font-variant-numeric:tabular-nums}.catch-stat-label{font-size:.75rem;color:var(--color-text-muted)}.catch-list{display:flex;flex-direction:column;gap:.6rem}.catch-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:.9rem 1rem;cursor:pointer;transition:border-color var(--transition),box-shadow var(--transition),transform var(--transition);display:flex;flex-direction:column;gap:.4rem}.catch-card:hover{border-color:var(--color-primary);box-shadow:0 0 8px var(--color-glow);transform:translateY(-1px)}.catch-card-header{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem}.catch-card-main{display:flex;align-items:center;gap:.5rem}.catch-species{font-weight:600;font-size:1rem;color:var(--color-text)}.catch-released-badge{font-size:.7rem;background:#4caf6c1f;border:1px solid rgba(76,175,108,.3);border-radius:20px;padding:.1rem .4rem;color:var(--color-success);font-weight:600}.catch-date{font-size:.8rem;color:var(--color-text-muted);flex-shrink:0}.catch-card-stats{display:flex;flex-wrap:wrap;gap:.35rem}.catch-card-stat{font-size:.78rem;color:var(--color-text-muted);background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:999px;padding:.1rem .5rem}.catch-notes{font-size:.82rem;color:var(--color-text-muted);line-height:1.5;font-style:italic}.fishguide-page{display:flex;flex-direction:column;gap:1.5rem;max-width:800px}.fishguide-header{display:flex;flex-direction:column;gap:.25rem}.fishguide-subtitle{color:var(--color-text-muted);font-size:.9rem}.fishguide-scenes{display:flex;flex-wrap:wrap;gap:.5rem}.scene-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:999px;color:var(--color-text-muted);font-size:.82rem;cursor:pointer;transition:border-color var(--transition),color var(--transition),background var(--transition)}.scene-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.scene-chip--active{background:#dc78321f;border-color:var(--color-primary);color:var(--color-primary)}.scene-chip--manual{border-style:dashed}.fishguide-input-area{display:flex;flex-direction:column;gap:.5rem}.fishguide-label{font-size:.85rem;color:var(--color-text-muted);font-weight:500}.fishguide-group-label{font-size:.78rem;color:var(--color-text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:.25rem}.fishguide-optional{font-size:.78rem;font-weight:400;opacity:.65}.fishguide-textarea{width:100%;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-family:inherit;font-size:.9rem;padding:.7rem .9rem;resize:vertical;min-height:80px;transition:border-color var(--transition)}.fishguide-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #dc783226}.fishguide-textarea::placeholder{color:var(--color-text-muted)}.fishguide-hint{font-size:.78rem;color:var(--color-text-muted)}.fishguide-warning{font-size:.82rem;color:var(--color-danger)}.fishguide-error{font-size:.82rem;color:var(--color-danger);margin-top:.25rem}.fishguide-result{display:flex;flex-direction:column;gap:.75rem}.fishguide-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.fishguide-card-title{font-size:.85rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.fishguide-advice{font-size:.9rem;line-height:1.7;color:var(--color-text);white-space:pre-wrap}.fishguide-gear-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.fishguide-gear-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.4rem .6rem;border-radius:var(--radius);border:1px solid var(--color-border);font-size:.875rem}.fishguide-gear-info{display:flex;align-items:center;gap:.3rem;flex:1}.fishguide-gear-name{font-weight:500;color:var(--color-text)}.fishguide-gear-brand{color:var(--color-text-muted);font-size:.82em}.fishguide-gear-weight{font-size:.78rem;color:var(--color-text-muted);flex-shrink:0}.wizard-steps{display:flex;align-items:center;margin-bottom:1.5rem}.wizard-step{display:flex;align-items:center;gap:.4rem;flex-shrink:0}.wizard-step-dot{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-surface-raised);color:var(--color-text-muted);font-size:.72rem;font-weight:600;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition),border-color var(--transition),color var(--transition),box-shadow var(--transition)}.wizard-step--done .wizard-step-dot{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text)}.wizard-step--active .wizard-step-dot{background:var(--color-primary);border-color:var(--color-primary);color:var(--color-primary-text);box-shadow:0 0 8px var(--color-glow)}.wizard-step-label{font-size:.78rem;color:var(--color-text-muted);white-space:nowrap;transition:color var(--transition)}.wizard-step--done .wizard-step-label{color:var(--color-text-muted)}.wizard-step--active .wizard-step-label{color:var(--color-primary);font-weight:600}.wizard-connector{flex:1;height:1.5px;background:var(--color-border);margin:0 .5rem;transition:background var(--transition)}.wizard-connector--done{background:var(--color-primary)}.wizard-panel{display:flex;flex-direction:column;gap:1.25rem}.wizard-nav{display:flex;align-items:center;justify-content:space-between;padding-top:.25rem}.wizard-nav--right{justify-content:flex-end}.wizard-item-name{font-weight:600;font-size:1rem}.wizard-item-meta{font-size:.8rem;color:var(--color-text-muted);margin-top:.15rem}.wizard-field-label{font-size:.8rem;color:var(--color-text-muted);font-weight:500;margin-top:.75rem;display:block}.wizard-input{width:100%;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .75rem;color:var(--color-text);font-size:.9rem;margin-top:.25rem;transition:border-color var(--transition)}.wizard-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #dc78321f}.modal-progress{font-size:.78rem;color:var(--color-text-muted);margin-left:auto;margin-right:.5rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modal-in .12s ease}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 32px 80px #00000080;animation:modal-in .12s ease}@keyframes modal-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-header h2,.modal-header h3{font-size:1rem;font-weight:600}.modal-body{padding:1.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:.9rem;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding:1rem 1.25rem;border-top:1px solid var(--color-border);flex-shrink:0}.export-modal{max-width:560px}.export-modal-body{gap:.75rem!important}.export-picker-box{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.6rem .75rem;display:flex;flex-direction:column;gap:.3rem}.export-picker-scroll{max-height:220px;overflow-y:auto}.export-picker-row{display:flex;align-items:center;gap:.5rem;padding:.2rem 0;font-size:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none}.export-picker-row--indented{padding-left:1.2rem}.export-picker-name{flex:1}.export-picker-muted{color:var(--color-text-muted)}.export-picker-count{font-size:.78rem;color:var(--color-text-muted)}.export-picker-group{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;padding:.35rem 0 .1rem}.export-picker-empty{color:var(--color-text-muted);font-size:.85rem;padding:.5rem 0}.export-section-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;padding-top:.25rem}.export-search{width:100%;padding:.4rem .6rem;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);font-size:.85rem;margin-bottom:.4rem}.export-search:focus{outline:none;border-color:var(--color-primary)}.export-column-picks{display:flex;flex-direction:column;gap:.3rem}.export-group-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer;-webkit-user-select:none;user-select:none}.danger-zone{margin-top:1.5rem;padding-top:1.25rem;border-top:1px solid rgba(196,64,64,.2)}.danger-zone-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-danger);margin-bottom:.75rem}.delete-confirm{display:flex;flex-direction:column;gap:.75rem}.delete-confirm-warning{font-size:.875rem;color:var(--color-danger);line-height:1.5}.delete-confirm-instruction{font-size:.875rem;color:var(--color-text-muted)}.delete-confirm-input{width:100%;background:var(--color-surface-raised);border:1px solid var(--color-danger);border-radius:var(--radius);padding:.5rem .75rem;color:var(--color-text);font-size:.875rem;font-family:monospace}.delete-confirm-input:focus{outline:none;box-shadow:0 0 0 2px #c440404d}.delete-confirm-actions{display:flex;gap:.5rem;justify-content:flex-end}.country-field{display:flex;align-items:center;gap:.5rem}.country-select{position:relative;flex:1}.country-select-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.875rem;color:var(--color-text);cursor:pointer;text-align:left;transition:border-color var(--transition)}.country-select-trigger:hover{border-color:var(--color-primary)}.country-select-placeholder{color:var(--color-text-muted)}.country-select-arrow{color:var(--color-text-muted);font-size:.75rem;flex-shrink:0;margin-left:.25rem}.country-select-dropdown{z-index:9999;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 8px 24px #00000080}.country-select-search{width:100%;box-sizing:border-box;padding:.5rem .75rem;border:none;border-bottom:1px solid var(--color-border);background:transparent;color:var(--color-text);font-size:.875rem}.country-select-search:focus{outline:none}.country-select-options{max-height:220px;overflow-y:auto}.country-select-option{display:flex;align-items:center;gap:.5rem;padding:.35rem .75rem;cursor:pointer;font-size:.875rem;transition:background 80ms}.country-select-option:hover{background:var(--color-surface)}.country-select-option--selected{color:var(--color-primary)}.country-select-option-code{font-size:.7rem;font-weight:700;width:2rem;color:var(--color-text-muted);flex-shrink:0}.country-code-badge{flex-shrink:0;min-width:2.5rem;padding:.4rem .5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.75rem;font-family:monospace;font-weight:700;text-align:center;color:var(--color-text-muted);letter-spacing:.05em}.field-row{display:flex;flex-direction:column;gap:.3rem}.field-row label{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.field-row input,.field-row select,.field-row textarea{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:.5rem .75rem;color:var(--color-text);font-size:.875rem;width:100%;transition:border-color var(--transition),box-shadow var(--transition)}.field-row input:focus,.field-row select:focus,.field-row textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #dc78321f}.field-group{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.field-group--2{grid-template-columns:1fr 1fr}.field-group--3{grid-template-columns:1fr 1fr 1fr}.input-with-action{display:flex;gap:.5rem}.input-with-action input{flex:1}.field-error{font-size:.8rem;color:var(--color-danger)}.field-hint{font-size:.75rem;color:var(--color-text-muted);font-style:italic}.tag-label-row{display:flex;align-items:center;justify-content:space-between}.tag-suggest-btn{font-size:.75rem}.tag-input-wrapper{display:flex;flex-wrap:wrap;gap:.35rem;padding:.4rem .5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);min-height:2.4rem;align-items:center;cursor:text;transition:border-color var(--transition)}.tag-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #dc78321f}.tag-chip{display:inline-flex;align-items:center;gap:.25rem;font-size:.75rem;background:#dc78321f;border:1px solid rgba(220,120,50,.3);border-radius:20px;padding:.1rem .5rem .1rem .6rem;color:var(--color-primary)}.tag-chip-remove{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:0;font-size:.85rem;line-height:1;display:flex;align-items:center}.tag-chip-remove:hover{color:var(--color-danger)}.tag-input-container{position:relative;flex:1;min-width:80px}.tag-input{background:transparent;border:none;outline:none;color:var(--color-text);font-size:.875rem;width:100%;padding:0}.tag-suggestions{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius);list-style:none;z-index:10;overflow:hidden;box-shadow:0 8px 24px #0006}.tag-suggestions li{padding:.4rem .75rem;font-size:.875rem;cursor:pointer}.tag-suggestions li:hover{background:var(--color-surface);color:var(--color-primary)}.ai-tag-suggestions{display:flex;flex-direction:column;gap:.4rem}.ai-tag-suggestions-label{font-size:.75rem;color:var(--color-text-muted)}.ai-tag-chips{display:flex;flex-wrap:wrap;gap:.35rem}.ai-tag-chip{display:inline-flex;align-items:center;gap:0}.ai-tag-chip-accept{background:#dc783214;border:1px solid rgba(220,120,50,.3);border-right:none;border-radius:20px 0 0 20px;padding:.15rem .6rem;font-size:.75rem;color:var(--color-primary);cursor:pointer}.ai-tag-chip-accept:hover{background:#dc783233}.ai-tag-chip .tag-chip-remove{background:#dc783214;border:1px solid rgba(220,120,50,.3);border-left:none;border-radius:0 20px 20px 0;padding:.15rem .4rem;font-size:.85rem}.photo-prompt{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius);font-size:.8rem;color:var(--color-text-muted)}.photo-confirm{display:flex;flex-direction:column;gap:.5rem}.photo-preview{width:100%;max-height:200px;object-fit:contain;border-radius:var(--radius);border:1px solid var(--color-border)}.photo-confirm-actions{display:flex;gap:.5rem;justify-content:flex-end}.lure-result-card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius);padding:.6rem .75rem;display:flex;flex-direction:column;gap:.25rem}.lure-result-uncertain{border-color:#dcb43266;background:#dcb4320f}.lure-result-found{font-size:.9rem;font-weight:600;color:var(--color-primary)}.lure-result-warning{font-size:.85rem;font-weight:600;color:var(--color-warning, #c48a20)}.lure-result-desc{font-size:.8rem;color:var(--color-text-muted)}.tags-page{display:flex;flex-direction:column;gap:1.25rem}.tags-page-header{display:flex;justify-content:space-between;align-items:center}.tags-page-header h2{font-size:1.4rem;font-weight:700;letter-spacing:-.02em}.tags-empty{color:var(--color-text-muted);font-style:italic;padding:2rem 0}.tags-list{display:flex;flex-direction:column;gap:.4rem}.tag-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);transition:border-color var(--transition)}.tag-row:hover{border-color:var(--color-primary)}.tag-row-checkbox{width:16px;height:16px;accent-color:var(--color-primary);flex-shrink:0}.tag-row-name{font-size:.875rem}.tag-row-edit{display:flex;gap:.4rem;align-items:center;flex:1}.tag-row-edit input{flex:1;padding:.3rem .5rem;font-size:.85rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text)}.tag-row-edit input:focus{outline:none;border-color:var(--color-primary)}.pick-list{list-style:none;display:flex;flex-direction:column;gap:.1rem;max-height:360px;overflow-y:auto}.pick-item{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.45rem .6rem;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;transition:background var(--transition),border-color var(--transition)}.pick-item:hover{background:var(--color-surface-raised);border-color:var(--color-border)}.pick-item-info{display:flex;align-items:center;gap:.4rem}.pick-item-name{font-size:.875rem;color:var(--color-text)}.pick-item-brand{font-size:.78rem;color:var(--color-text-muted)}.pick-item-weight{font-size:.78rem;color:var(--color-text-muted);flex-shrink:0}.location-input{position:relative;width:100%}.location-input-row{display:flex;gap:.25rem;align-items:center}.location-input-row input{flex:1;min-width:0}.location-search-btn{flex-shrink:0;padding:0 .5rem;font-size:1rem;line-height:1;color:var(--color-text-muted)}.location-search-btn:hover,.location-search-btn--active{color:var(--color-primary)}.location-suggestions{position:absolute;top:calc(100% + 2px);left:0;right:0;z-index:200;background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius);list-style:none;max-height:240px;overflow-y:auto}.location-suggestions li{display:flex;flex-direction:column;gap:.1rem;padding:.5rem .75rem;cursor:pointer}.location-suggestions li:hover{background:var(--color-surface)}.location-suggestion-label{font-size:.875rem;color:var(--color-text)}.location-suggestion-sub{font-size:.75rem;color:var(--color-text-muted)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}
