*{box-sizing:border-box}:root{--color-primary: #22c55e;--color-primary-light: #4ade80;--color-primary-dark: #16a34a;--color-error: #ef4444;--color-warning: #facc15;--color-text: #1f2937;--color-text-muted: #6b7280;--color-text-light: #9ca3af;--color-bg: #f9fafb;--color-bg-white: #ffffff;--color-border: #e5e7eb;--space-xs: 4px;--space-sm: 8px;--space-md: 12px;--space-lg: 16px;--space-xl: 24px;--space-2xl: 32px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 20px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .12);--shadow-primary: 0 4px 12px rgba(74, 222, 128, .3);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg-white);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}a{color:#3b82f6;text-decoration:none}a:hover{text-decoration:underline}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.tree-card{background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .3s ease;cursor:pointer}.tree-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.tree-card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:16px 16px 12px;border-bottom:1px solid #f3f4f6}.tree-info{flex:1}.tree-name{font-size:16px;font-weight:600;margin:0 0 2px;color:#1f2937}.tree-variety{font-size:13px;color:#6b7280;margin:0;text-transform:capitalize}.tree-menu{background:#f3f4f6;border:none;font-size:20px;color:#374151;cursor:pointer;min-width:44px;min-height:44px;padding:12px;border-radius:8px;transition:all .2s;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center}.tree-menu:hover{background:#e5e7eb;color:#111827;transform:scale(1.05)}.tree-card-body{padding:20px;min-height:200px;display:flex;flex-direction:column;align-items:center;gap:16px}.ripeness-display{margin:20px 0}.ripeness-circle{width:120px;height:120px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.ripeness-inner{width:100px;height:100px;background:#fff;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.ripeness-emoji{font-size:32px;margin-bottom:4px}.ripeness-value{font-size:20px;font-weight:700;color:#1f2937}.mini-trend{display:flex;align-items:flex-end;gap:3px;height:32px;width:100%;padding:8px 12px;background:#f9fafb;border-radius:8px}.trend-bar{flex:1;border-radius:3px 3px 0 0;transition:all .3s ease;min-height:4px;max-width:20px}.trend-bar:hover{opacity:.8;transform:scaleY(1.05)}.no-data{text-align:center;color:#9ca3af;padding:40px 20px}.phase-display{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px}.phase-icon-large{font-size:64px}.phase-label-large{font-size:18px;font-weight:600;color:#374151}.latest-photo-thumb{width:100%;aspect-ratio:16/9;border-radius:8px;overflow:hidden;background:#f3f4f6;margin-bottom:8px}.latest-photo-thumb img{width:100%;height:100%;object-fit:cover}.latest-check-info{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#f9fafb;border-radius:8px;width:100%;justify-content:center}.check-phase{font-size:14px;font-weight:500;color:#374151}.check-date{font-size:12px;color:#6b7280}.tree-meta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:auto}.meta-item{font-size:12px;color:#6b7280;display:flex;align-items:center;gap:4px}.tree-card-actions{padding:16px 20px;border-top:1px solid #f3f4f6;background:#fafafa}.action-button{width:100%;padding:12px 16px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.action-button.primary{background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff}.action-button.primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4ade804d}.button-icon{font-size:18px}@media (max-width: 768px){.tree-card{border-radius:12px}.tree-card-header{padding:14px 16px}.tree-name{font-size:15px}.tree-variety{font-size:12px}.tree-card-body{padding:16px;min-height:160px;gap:12px}.ripeness-circle{width:90px;height:90px}.ripeness-inner{width:72px;height:72px}.ripeness-emoji{font-size:26px}.ripeness-value{font-size:18px}.mini-trend{height:32px}.tree-meta{gap:8px}.meta-item{font-size:11px}.tree-card-actions{padding:12px 16px}.action-button{padding:14px 16px;min-height:48px;font-size:15px}.latest-photo-thumb{aspect-ratio:4/3;margin-bottom:6px}.latest-check-info{padding:6px 10px;gap:8px}.check-phase{font-size:13px}.check-date{font-size:11px}}.fruit-variety-container{display:flex;flex-direction:column;gap:20px}.fruit-type-selector{display:flex;flex-direction:column;gap:12px}.fruit-type-selector label,.variety-select-wrapper label{font-weight:500;color:#374151;margin-bottom:8px;display:block}.fruit-type-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}.fruit-type-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .2s}.fruit-type-btn:hover{background:#f3f4f6;border-color:#d1d5db}.fruit-type-btn.active{background:#4ade801a;border-color:#4ade80}.fruit-icon{font-size:32px}.fruit-name{font-size:14px;font-weight:500;color:#374151}.fruit-type-btn.active .fruit-name{color:#15803d}.variety-select-wrapper{display:flex;flex-direction:column;gap:8px}.variety-select{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;background-color:#fff;cursor:pointer;transition:all .2s;appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 12px center;background-size:20px}.variety-select:focus{outline:none;border-color:#4ade80;box-shadow:0 0 0 3px #4ade801a}.variety-info{background-color:#f0fdf4;padding:12px;border-radius:8px;font-size:14px;border:1px solid #bbf7d0}.info-item{display:flex;justify-content:space-between;align-items:center}.info-label{color:#15803d}.info-value{font-weight:600;color:#166534}.tree-onboarding{background:#fff;border-radius:20px;overflow:hidden;max-width:500px;margin:0 auto}.onboarding-header{padding:24px 24px 20px;text-align:center;border-bottom:1px solid #f3f4f6}.onboarding-header h2{font-size:24px;margin:0 0 8px;color:#1f2937}.subtitle{color:#22c55e;font-size:14px;margin:0;font-weight:500}.onboarding-form{padding:24px}.step-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-icon{font-size:64px;text-align:center;margin-bottom:24px}.step-content h3{text-align:center;margin:0 0 8px;font-size:20px}.step-content>p{text-align:center;color:#6b7280;margin:0 0 32px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151}.form-group input[type=text],.form-group input[type=date],.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:all .2s;-webkit-appearance:none;appearance:none}@media screen and (max-width: 768px){.form-group input[type=text],.form-group input[type=date],.form-group textarea,.form-group select{font-size:16px!important}}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.error-message{color:#ef4444;font-size:14px;margin-top:4px;display:block}.form-actions{display:flex;justify-content:flex-end;align-items:center;gap:12px;padding:24px 0 0;margin-top:24px;border-top:1px solid #f3f4f6}.btn-text{background:none;border:none;color:#6b7280;font-size:16px;cursor:pointer;padding:12px 24px}.btn-text:hover{color:#374151}.quick-check{background:#fff;border-radius:20px;padding:24px;max-width:600px;margin:0 auto}.quick-check-header{text-align:center;margin-bottom:32px}.header-title-row{display:flex;justify-content:center;align-items:center;position:relative}.quick-check-header h2{margin:0 0 8px;font-size:24px}.quick-check-header .close-button{position:absolute;right:0;top:50%;transform:translateY(-50%);background:none;border:none;font-size:32px;color:#9ca3af;cursor:pointer;padding:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.quick-check-header .close-button:hover{background:#f3f4f6;color:#374151}.date-label{color:#6b7280;font-size:14px;margin:0}.quick-check-form{display:flex;flex-direction:column;gap:32px}.phase-section{text-align:center}.phase-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:16px}@media (max-width: 480px){.phase-buttons{grid-template-columns:repeat(2,1fr)}}.ripeness-section{text-align:center}.section-label{display:block;font-weight:600;color:#374151;margin-bottom:20px;font-size:16px}.ripeness-slider-container{background:#f9fafb;border-radius:16px;padding:32px 24px 24px}.ripeness-display-large{margin-bottom:32px}.ripeness-circle-large{width:140px;height:140px;border:8px solid;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;transition:all .3s ease;background:#fff;box-shadow:0 4px 12px #0000001a}.ripeness-number{font-size:48px;font-weight:700;color:#1f2937}.ripeness-percent{font-size:24px;font-weight:500;color:#6b7280;margin-left:2px}.ripeness-description{font-size:18px;color:#4b5563;margin:0}.ripeness-slider{-webkit-appearance:none;width:100%;height:8px;border-radius:4px;outline:none;margin-bottom:16px}.ripeness-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0003;border:2px solid currentColor}.ripeness-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0003;border:2px solid currentColor}.slider-labels{display:flex;justify-content:space-between;font-size:14px;color:#6b7280}.quick-options{display:flex;flex-direction:column;gap:24px}.option-group label{display:block;font-weight:500;color:#374151;margin-bottom:12px}.option-button{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:16px 8px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:24px}.option-button span{font-size:12px;color:#6b7280;text-transform:capitalize}.measurement-section{margin-bottom:24px}.measurement-section label{display:block;font-weight:500;color:#374151;margin-bottom:8px}.measurement-input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:all .2s}.measurement-input:focus{outline:none;border-color:#4ade80;box-shadow:0 0 0 3px #4ade801a}.measurement-hint{font-size:13px;color:#6b7280;margin-top:4px}.notes-section label{display:block;font-weight:500;color:#374151;margin-bottom:8px}.notes-section textarea{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;resize:none;transition:all .2s}.notes-section textarea:focus{outline:none;border-color:#4ade80;box-shadow:0 0 0 3px #4ade801a}.form-actions{display:flex;gap:12px;justify-content:center;margin-top:8px;padding-bottom:20px}.btn-primary,.btn-secondary{padding:14px 32px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;flex:1}@media (max-width: 768px){.quick-check{padding:20px;border-radius:20px 20px 0 0}.option-buttons{gap:6px}.option-button{padding:12px 4px}}.photo-section{margin-bottom:24px}.photo-section label{display:block;font-weight:500;color:#374151;margin-bottom:12px}.photo-options{display:flex;gap:12px}.photo-button{flex:1;padding:16px;border:2px dashed #e5e7eb;border-radius:8px;background:#fff;font-size:16px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:8px}.photo-button:hover{border-color:#4ade80;background:#4ade800d}.photo-button.camera{border-color:#60a5fa}.photo-button.camera:hover{background:#60a5fa0d}.camera-view{position:relative;border-radius:8px;overflow:hidden;background:#000}.camera-preview{width:100%;height:auto;display:block}.camera-controls{position:absolute;bottom:20px;left:0;right:0;display:flex;justify-content:center;gap:12px;padding:0 20px}.capture-button,.cancel-camera-button{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.capture-button{background:#4ade80;color:#fff}.capture-button:hover{background:#22c55e;transform:scale(1.05)}.cancel-camera-button{background:#ffffffe6;color:#374151}.cancel-camera-button:hover{background:#fff}.photo-preview{position:relative;border-radius:8px;overflow:hidden}.photo-preview img{width:100%;height:auto;display:block}.remove-photo-button{position:absolute;top:12px;right:12px;background:#ffffffe6;border:none;padding:8px 12px;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;color:#374151}.remove-photo-button:hover{background:#fff;transform:scale(1.05)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px}.photo-grid-item{position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;background:#f3f4f6}.photo-grid-item img{width:100%;height:100%;object-fit:cover}.photo-grid-item.uploading{opacity:.7}.photo-grid-item.error{border:2px solid #ef4444}.photo-grid-item.uploaded{border:2px solid #4ade80}.photo-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#00000080}.photo-overlay.success{background:#4ade804d}.photo-overlay.success span{color:#fff;font-weight:600;font-size:12px;background:#22c55e;padding:4px 8px;border-radius:4px}.photo-overlay.error{background:#ef44444d}.photo-overlay.error span{color:#fff;font-weight:600;font-size:12px;background:#ef4444;padding:4px 8px;border-radius:4px}.photo-overlay.error{flex-direction:column;gap:8px}.retry-upload-btn{background:#fff;color:#ef4444;border:none;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;min-width:44px;min-height:32px;transition:all .2s}.retry-upload-btn:hover:not(:disabled){background:#fee2e2}.retry-upload-btn:disabled{opacity:.6;cursor:not-allowed}.upload-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.remove-photo-btn{position:absolute;top:4px;right:4px;width:44px;height:44px;border-radius:50%;background:#0009;border:none;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-photo-btn:hover{background:#ef4444;transform:scale(1.1)}.loading-indicator{color:#9ca3af;font-weight:400}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 480px){.photo-grid{grid-template-columns:repeat(2,1fr);gap:8px}.quick-check{padding:16px}.quick-check-header h2{font-size:20px}.section-label{font-size:15px}.phase-button{padding:12px 6px}.phase-icon{font-size:24px}.ripeness-circle-large{width:120px;height:120px;border-width:6px}.ripeness-number{font-size:40px}.btn-primary,.btn-secondary{min-height:48px;font-size:16px}.form-actions{flex-direction:column;gap:10px}.form-actions .btn-secondary{order:2}.form-actions .btn-primary{order:1}}@supports (padding: max(0px)){.quick-check{padding-bottom:max(24px,env(safe-area-inset-bottom))}}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:2000;display:flex;align-items:flex-end;animation:fadeIn .3s ease;touch-action:none;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;isolation:isolate;pointer-events:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;width:100%;max-height:90vh;border-radius:20px 20px 0 0;padding:0 0 env(safe-area-inset-bottom) 0;padding-bottom:max(env(safe-area-inset-bottom),20px);transition:transform .3s ease;animation:slideUp .3s ease;overflow:hidden;position:relative;touch-action:pan-y;-webkit-user-select:none;user-select:none;pointer-events:auto}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-title{font-size:20px;font-weight:600;text-align:center;margin:0 20px 20px;padding-bottom:20px;border-bottom:1px solid #f3f4f6}.modal-body{padding:0 20px 100px;overflow-y:auto;max-height:calc(90vh - 100px);-webkit-overflow-scrolling:touch}@supports (padding: max(0px)){.modal-body{padding-bottom:max(100px,env(safe-area-inset-bottom))}}.modal-body:has(input:focus,textarea:focus){padding-bottom:280px}@media (min-width: 768px){.modal-overlay{align-items:center;justify-content:center}.modal-content{max-width:500px;max-height:80vh;border-radius:20px;margin:20px}}.orchard-map-container{position:relative;background:transparent;border-radius:0;padding:0;box-shadow:none;height:100%;display:flex;flex-direction:column}.orchard-map-wrapper{flex:1;display:flex;justify-content:center;align-items:center;min-height:0;overflow:hidden}.orchard-svg{width:100%;height:100%;max-width:none;border:none;border-radius:0;background:#1a1a1a;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}body:has(.modal-overlay) .orchard-svg{pointer-events:none}.svg-tree-marker{transition:transform .1s ease-out}.svg-tree-marker:hover circle{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.svg-tree-marker.selected circle{filter:drop-shadow(0 0 8px rgba(74,222,128,.5))}.svg-tree-marker.dragging{opacity:.8}.svg-tree-marker .tree-emoji{font-family:"Segoe UI Emoji","Apple Color Emoji","Noto Color Emoji",sans-serif;pointer-events:none}@media (max-width: 768px){.orchard-map-container{padding:0;border-radius:0;height:100%}.orchard-map-wrapper{flex:1}.orchard-svg{max-width:none;max-height:none}}@media (min-width: 769px){.orchard-map-container{max-height:none}.orchard-svg{max-width:none}}.floating-drag-toggle{position:absolute;top:12px;left:12px;padding:10px 16px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;z-index:10;box-shadow:0 2px 8px #00000026;transition:all .2s}.floating-drag-toggle:hover{border-color:#4ade80}.floating-drag-toggle.active{background:#4ade80;border-color:#4ade80;color:#fff}@media (prefers-reduced-motion: reduce){.svg-tree-marker{transition:none}}.tree-edit-modal{background:#fff;border-radius:20px;max-width:500px;margin:0 auto}.modal-header{padding:24px 24px 0;text-align:center;border-bottom:1px solid #f3f4f6;margin-bottom:24px}.subtitle{color:#22c55e;font-size:14px;margin:0 0 16px;font-weight:500}.edit-form{padding:0 24px 24px}.form-section{margin-bottom:32px}.form-section h3{font-size:16px;font-weight:600;color:#374151;margin:0 0 16px;display:flex;align-items:center;gap:8px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#374151;font-size:14px}.form-group input[type=text],.form-group input[type=date],.form-group textarea{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:all .2s;font-family:inherit}.form-group input.error,.form-group textarea.error{border-color:#ef4444}.error-message{color:#ef4444;font-size:13px;margin-top:4px;display:block}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}@media (max-width: 480px){.form-row{grid-template-columns:1fr}}.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:32px;padding-top:24px;border-top:1px solid #f3f4f6}.action-buttons{display:flex;gap:12px}.btn-secondary{background:#f3f4f6;color:#374151;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-delete{background:transparent;color:#ef4444;border:2px solid #fecaca;padding:10px 20px;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.btn-delete:hover{background:#fef2f2;border-color:#ef4444}.btn-delete.confirm{background:#ef4444;color:#fff;border-color:#ef4444;animation:pulse .5s}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@media (max-width: 480px){.edit-form{padding:0 16px 16px}.form-section{margin-bottom:24px}.form-actions{flex-direction:column;gap:16px}.action-buttons{width:100%;flex-direction:column-reverse}.action-buttons button,.btn-delete{width:100%}}.recent-checks{max-width:800px;margin:0 auto}.checks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.checks-header h2{margin:0;font-size:24px;color:#1f2937}.tree-filter{padding:8px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;background:#fff;cursor:pointer}.tree-filter:focus{outline:none;border-color:#4ade80}.loading{text-align:center;padding:40px;color:#6b7280}.no-checks{text-align:center;padding:60px 20px;color:#9ca3af}.checks-list{display:flex;flex-direction:column;gap:16px}.check-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014;transition:all .2s}.check-card:hover{box-shadow:0 4px 12px #0000001f}.check-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.check-info h4{margin:0 0 4px;font-size:18px;color:#1f2937}.check-date{margin:0;font-size:14px;color:#6b7280;text-transform:capitalize}.check-actions{display:flex;gap:8px}.action-btn{background:#f3f4f6;border:none;width:36px;height:36px;border-radius:8px;cursor:pointer;transition:all .2s;font-size:16px;display:flex;align-items:center;justify-content:center}.action-btn:hover{background:#e5e7eb;transform:scale(1.05)}.action-btn.delete:hover{background:#fee2e2;color:#dc2626}.check-content{display:flex;flex-direction:column;gap:16px}.check-phase{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f9fafb;border-radius:8px;width:fit-content}.phase-icon{font-size:24px}.phase-label{font-weight:500;color:#374151}.check-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.metric{display:flex;flex-direction:column;gap:4px}.metric label{font-size:13px;color:#6b7280;font-weight:500}.metric-value{position:relative;background:#f3f4f6;border-radius:4px;height:24px;overflow:hidden;display:flex;align-items:center;justify-content:flex-end;padding-right:8px}.ripeness-bar{position:absolute;left:0;top:0;bottom:0;transition:width .3s ease}.metric-value span{position:relative;font-size:13px;font-weight:600;color:#1f2937}.check-notes{background:#f9fafb;padding:12px;border-radius:8px}.check-notes label{display:block;font-size:13px;color:#6b7280;font-weight:500;margin-bottom:4px}.check-notes p{margin:0;font-size:14px;color:#374151}.check-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-bottom:16px}.check-photo-thumb{aspect-ratio:4/3;border-radius:12px;overflow:hidden;cursor:pointer;background:#f3f4f6}.check-photo-thumb img{width:100%;height:100%;object-fit:cover;display:block}.photo-lightbox{position:fixed;inset:0;background:#000000f2;z-index:3000;display:flex;align-items:center;justify-content:center;padding:20px;padding-bottom:max(20px,env(safe-area-inset-bottom))}.lightbox-content{position:relative;max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:calc(100vh - 120px);border-radius:8px;object-fit:contain}.lightbox-close{position:absolute;top:-50px;right:0;width:44px;height:44px;border-radius:50%;background:#fff3;border:none;color:#fff;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.lightbox-caption{color:#fff;margin-top:16px;font-size:14px;text-align:center}@media (max-width: 768px){.checks-header{flex-direction:column;gap:12px;align-items:stretch}.checks-header h2{font-size:20px}.tree-filter{width:100%;min-height:44px;font-size:16px}.check-card{padding:16px;border-radius:12px}.check-info h4{font-size:16px}.action-btn{min-width:44px;min-height:44px}.check-photos-grid{grid-template-columns:repeat(3,1fr);gap:6px}.check-photo-thumb{border-radius:6px}.lightbox-close{top:auto;bottom:20px;right:50%;transform:translate(50%);width:56px;height:56px;font-size:32px}.lightbox-content img{max-height:calc(100vh - 180px)}}@supports (padding: max(0px)){.recent-checks{padding-bottom:max(20px,env(safe-area-inset-bottom))}}.compare-view{max-width:1200px;margin:0 auto;padding:20px}.compare-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.compare-header h2{margin:0;font-size:28px;color:#1f2937}.date-range-selector{display:flex;align-items:center;gap:12px}.date-range-select{padding:8px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;background:#fff;cursor:pointer}.date-range-select:focus{outline:none;border-color:#4ade80}.compare-controls{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px}.control-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #00000014}.control-section h3{margin:0 0 16px;font-size:16px;color:#374151}.tree-selector,.metric-selector{display:flex;flex-direction:column;gap:12px}.tree-option,.metric-option{display:flex;align-items:center;gap:8px;cursor:pointer;padding:8px 12px;border-radius:8px;transition:background .2s}.tree-option:hover,.metric-option:hover{background:#f9fafb}.tree-option input[type=checkbox],.metric-option input[type=checkbox]{width:18px;height:18px;cursor:pointer}.tree-option span,.metric-option span{font-size:15px;color:#374151}.charts-container{display:flex;flex-direction:column;gap:32px}.chart-wrapper{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #00000014}.chart-wrapper h4{margin:0 0 20px;font-size:18px;color:#1f2937}.chart-container{height:300px;position:relative}.no-selection,.no-data{text-align:center;padding:60px 20px;color:#9ca3af;background:#f9fafb;border-radius:12px}.loading{text-align:center;padding:60px;color:#6b7280}@media (max-width: 768px){.compare-header{flex-direction:column;gap:16px;align-items:stretch}.date-range-select{width:100%}.compare-controls{grid-template-columns:1fr}.chart-container{height:250px}}.check-edit-modal{background:#fff;border-radius:20px;max-width:600px;margin:0 auto}.modal-header{padding:24px 24px 20px;text-align:center;border-bottom:1px solid #f3f4f6}.modal-header h2{margin:0 0 8px;font-size:24px;color:#1f2937}.subtitle{color:#6b7280;font-size:14px;margin:0}.edit-form{padding:24px;display:flex;flex-direction:column;gap:32px}.form-section{display:flex;flex-direction:column;gap:16px}.section-label{font-weight:600;color:#374151;font-size:16px}.phase-buttons{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.phase-button{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:16px 8px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:8px}.phase-button:hover{background:#f3f4f6;border-color:#d1d5db}.phase-button.active{background:#4ade801a;border-color:#4ade80}.phase-icon{font-size:28px}.ripeness-slider-container{background:#f9fafb;border-radius:16px;padding:24px}.ripeness-display{text-align:center;margin-bottom:24px}.ripeness-circle{width:100px;height:100px;border:6px solid;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;background:#fff;transition:all .3s ease}.ripeness-number{font-size:32px;font-weight:700;color:#1f2937}.ripeness-percent{font-size:18px;font-weight:500;color:#6b7280}.ripeness-description{font-size:16px;color:#4b5563;margin:0}.ripeness-slider{-webkit-appearance:none;width:100%;height:8px;border-radius:4px;outline:none}.ripeness-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 8px #0003;border:2px solid currentColor}.option-group{display:flex;flex-direction:column;gap:12px}.option-group label{font-weight:500;color:#374151}.option-buttons{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.option-button{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:12px 8px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:6px;font-size:20px}.option-button span{font-size:12px;color:#6b7280}.option-button:hover{background:#f3f4f6;border-color:#d1d5db}.option-button.active{background:#4ade801a;border-color:#4ade80}.option-button.active span{color:#15803d;font-weight:500}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:500;color:#374151}.form-group input,.form-group textarea{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:all .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4ade80;box-shadow:0 0 0 3px #4ade801a}.field-hint{font-size:13px;color:#6b7280;margin:0}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:24px;border-top:1px solid #f3f4f6}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4ade804d}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}@media (max-width: 480px){.phase-buttons{grid-template-columns:repeat(2,1fr)}.option-buttons{gap:6px}.option-button{padding:10px 4px}}.database-debug{max-width:1400px;margin:0 auto;padding:20px}.debug-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.debug-header h1{margin:0;color:#1f2937;font-size:32px}.refresh-btn{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:16px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:all .2s}.refresh-btn:hover{background:#2563eb;transform:translateY(-1px)}.error-banner{background:#fee2e2;color:#dc2626;padding:12px 20px;border-radius:8px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;color:#dc2626;font-size:20px;cursor:pointer}.debug-tabs{display:flex;gap:4px;background:#f3f4f6;padding:4px;border-radius:12px;margin-bottom:24px}.tab{background:transparent;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s}.tab:hover{color:#374151;background:#ffffff80}.tab.active{background:#fff;color:#1f2937;box-shadow:0 1px 3px #0000001a}.debug-content{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a}.status-section h2{margin-top:0;margin-bottom:24px;color:#1f2937}.status-grid{display:grid;gap:16px}.status-item{display:grid;grid-template-columns:150px 1fr;gap:16px;padding:12px;background:#f9fafb;border-radius:8px}.status-item .label{font-weight:600;color:#6b7280}.status-item .value{font-family:monospace;color:#374151}.status-item .value.connected{color:#10b981;font-weight:600}.status-item .value.disconnected{color:#ef4444;font-weight:600}.tables-section h2{margin-top:0;margin-bottom:24px;color:#1f2937}.tables-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;margin-bottom:32px}.table-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s}.table-card:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.table-card.selected{border-color:#3b82f6;background:#eff6ff}.table-card h3{margin:0 0 12px;color:#1f2937;font-size:18px}.table-info{display:flex;flex-direction:column;gap:4px;font-size:14px;color:#6b7280}.table-data{margin-top:24px;padding-top:24px;border-top:1px solid #e5e7eb}.table-data h3{margin:0 0 16px;color:#1f2937}.limit-warning{background:#fef3c7;color:#92400e;padding:8px 16px;border-radius:6px;font-size:14px;margin-bottom:16px}.data-table-wrapper{overflow-x:auto;border:1px solid #e5e7eb;border-radius:8px}.data-table{width:100%;border-collapse:collapse}.data-table th{background:#f3f4f6;padding:12px;text-align:left;font-weight:600;color:#374151;border-bottom:1px solid #e5e7eb}.data-table td{padding:12px;border-bottom:1px solid #f3f4f6;font-size:14px;color:#4b5563;font-family:monospace}.data-table tr:hover{background:#f9fafb}.models-section h2{margin-top:0;margin-bottom:24px;color:#1f2937}.model-card{background:#f9fafb;border-radius:12px;padding:24px;margin-bottom:20px}.model-card h3{margin:0 0 8px;color:#1f2937;font-size:20px}.model-info{color:#6b7280;font-size:14px;margin-bottom:20px}.model-card h4{margin:20px 0 12px;color:#374151;font-size:16px}.columns-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.columns-table th{background:#e5e7eb;padding:10px;text-align:left;font-size:14px;font-weight:600;color:#374151}.columns-table td{padding:10px;border-top:1px solid #f3f4f6;font-size:14px;color:#4b5563}.relationships{list-style:none;padding:0;margin:0}.relationships li{padding:8px 16px;background:#fff;border-radius:6px;margin-bottom:8px;font-size:14px;color:#4b5563}.stats-section h2{margin-top:0;margin-bottom:24px;color:#1f2937}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.stat-card{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:16px;padding:24px;text-align:center}.stat-card h3{margin:0 0 16px;font-size:20px;color:#374151}.stat-value{font-size:48px;font-weight:700;color:#1f2937;margin-bottom:16px}.stat-breakdown{display:flex;justify-content:center;gap:20px;font-size:14px;color:#6b7280}.stat-details{font-size:14px;color:#6b7280;line-height:1.5}.query-section h2{margin-top:0;margin-bottom:16px;color:#1f2937}.query-warning{background:#fef3c7;color:#92400e;padding:12px 20px;border-radius:8px;margin-bottom:24px;font-size:14px}.query-input{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.query-input textarea{width:100%;padding:16px;border:2px solid #e5e7eb;border-radius:8px;font-family:monospace;font-size:14px;resize:vertical}.query-input textarea:focus{outline:none;border-color:#3b82f6}.execute-btn{background:#10b981;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:8px;align-self:flex-start;transition:all .2s}.execute-btn:hover{background:#059669;transform:translateY(-1px)}.query-result{background:#f9fafb;border-radius:8px;padding:20px}.query-error{color:#dc2626;font-family:monospace;font-size:14px}.loading{text-align:center;padding:60px;color:#6b7280;font-size:18px}@media (max-width: 768px){.debug-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{white-space:nowrap}.status-item{grid-template-columns:1fr;gap:8px}.tables-grid,.stats-grid{grid-template-columns:1fr}}.photo-gallery-container{background:#fff;border-radius:16px;padding:24px;max-width:900px;margin:0 auto;max-height:80vh;overflow-y:auto}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.gallery-title h2{margin:0;font-size:20px;color:#1f2937}.photo-count{color:#6b7280;font-size:14px;margin-top:4px}.close-gallery-btn{background:#f3f4f6;border:none;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.close-gallery-btn:hover{background:#e5e7eb}.gallery-loading,.gallery-error,.gallery-empty{text-align:center;padding:48px 24px;color:#6b7280}.loading-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#4ade80;border-radius:50%;margin:0 auto 16px;animation:spin .8s linear infinite}.gallery-error button,.gallery-empty button{margin-top:16px;background:#4ade80;color:#fff;border:none;padding:10px 24px;border-radius:8px;cursor:pointer}.gallery-empty .hint{font-size:14px;margin-top:8px;color:#9ca3af}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.gallery-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .2s;background:#f3f4f6}.gallery-item:hover{transform:scale(1.02)}.gallery-item.deleting{opacity:.5;pointer-events:none}.gallery-item img{width:100%;height:100%;object-fit:cover}.gallery-item-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b3);padding:24px 10px 10px;display:flex;flex-direction:column;gap:4px}.photo-date{color:#fff;font-size:12px}.photo-type{color:#fffc;font-size:11px;text-transform:capitalize}.delete-photo-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:#00000080;border:none;color:#fff;font-size:16px;cursor:pointer;opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.gallery-item:hover .delete-photo-btn{opacity:1}.delete-photo-btn:hover{background:#ef4444}.photo-lightbox{position:fixed;inset:0;background:#000000e6;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.lightbox-close{position:absolute;top:-40px;right:0;width:36px;height:36px;border-radius:50%;background:#fff3;border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.lightbox-close:hover{background:#ffffff4d}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#fff3;border:none;color:#fff;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.lightbox-nav:hover{background:#ffffff4d}.lightbox-nav.prev{left:-60px}.lightbox-nav.next{right:-60px}.lightbox-info{position:absolute;bottom:-50px;left:0;right:0;text-align:center;color:#fff}.lightbox-date{margin:0;font-size:14px;color:#fffc}.lightbox-caption{margin:4px 0 0;font-size:16px}.lightbox-type{display:inline-block;margin-top:8px;padding:4px 12px;background:#fff3;border-radius:12px;font-size:12px;text-transform:capitalize}@media (max-width: 768px){.photo-gallery-container{padding:16px;border-radius:16px 16px 0 0;max-height:90vh}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:8px}.gallery-item{border-radius:8px}.lightbox-nav.prev{left:10px}.lightbox-nav.next{right:10px}.delete-photo-btn{opacity:1}}.photo-timeline{padding:16px}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.timeline-header h3{margin:0;font-size:18px;color:#1f2937}.timeline-count{color:#6b7280;font-size:14px}.photo-timeline-loading,.photo-timeline-error,.photo-timeline-empty{text-align:center;padding:48px 24px;color:#6b7280}.timeline-spinner{width:28px;height:28px;border:3px solid #e5e7eb;border-top-color:#4ade80;border-radius:50%;margin:0 auto 12px;animation:spin .8s linear infinite}.photo-timeline-error button{margin-top:12px;background:#4ade80;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer}.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.empty-hint{font-size:13px;color:#9ca3af;margin-top:8px}.timeline-content{position:relative}.timeline-month{margin-bottom:32px}.month-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.month-line{flex:1;height:1px;background:#e5e7eb}.month-label{font-size:14px;font-weight:600;color:#6b7280;text-transform:capitalize;white-space:nowrap}.month-photos{position:relative;padding-left:24px}.timeline-photo{position:relative;margin-bottom:16px;cursor:pointer}.timeline-dot{position:absolute;left:-24px;top:20px;width:12px;height:12px;background:#4ade80;border-radius:50%;border:3px solid white;box-shadow:0 0 0 2px #e5e7eb;z-index:1}.timeline-connector{position:absolute;left:-19px;top:32px;bottom:-16px;width:2px;background:#e5e7eb}.timeline-photo:last-child .timeline-connector{display:none}.photo-card{display:flex;background:#f9fafb;border-radius:12px;overflow:hidden;transition:all .2s;border:1px solid #e5e7eb}.photo-card:hover{transform:translate(4px);border-color:#4ade80;box-shadow:0 2px 8px #00000014}.photo-card img{width:60px;height:60px;object-fit:cover;flex-shrink:0}.photo-card-info{padding:10px 14px;display:flex;flex-direction:column;justify-content:center;gap:4px;min-width:0}.photo-card-date{font-size:14px;font-weight:500;color:#1f2937}.photo-card-caption{font-size:13px;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 480px){.photo-timeline{padding:12px}.month-photos{padding-left:20px}.timeline-dot{left:-20px;width:10px;height:10px}.timeline-connector{left:-16px}.photo-card img{width:50px;height:50px}}.tree-detail{background:#fff;border-radius:16px;max-width:700px;margin:0 auto;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.tree-detail-loading{padding:48px;text-align:center;color:#6b7280}.detail-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top-color:#4ade80;border-radius:50%;margin:0 auto 16px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.detail-header{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:flex-start}.detail-header-content{display:flex;align-items:center;gap:16px}.tree-icon-large{font-size:48px}.tree-info-main h2{margin:0;font-size:22px;color:#1f2937}.tree-variety{margin:4px 0 0;color:#6b7280;font-size:14px}.ripeness-badge-large{display:flex;flex-direction:column;align-items:center;padding:10px 16px;border:3px solid;border-radius:12px;background:#fff}.ripeness-value{font-size:24px;font-weight:700;color:#1f2937}.ripeness-label{font-size:12px;color:#6b7280}.close-detail-btn{background:#f3f4f6;border:none;padding:8px 16px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.close-detail-btn:hover{background:#e5e7eb}.detail-tabs{display:flex;padding:0 24px;border-bottom:1px solid #e5e7eb;overflow-x:auto}.tab-button{background:none;border:none;padding:14px 20px;min-height:44px;font-size:14px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s;white-space:nowrap}.tab-button:hover{color:#374151}.tab-button.active{color:#4ade80;border-bottom-color:#4ade80}.detail-content{flex:1;overflow-y:auto;padding:24px}.overview-tab{display:flex;flex-direction:column;gap:24px}.info-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.info-card{display:flex;align-items:center;gap:12px;background:#f9fafb;padding:14px 16px;border-radius:12px}.info-icon{font-size:24px}.info-content{display:flex;flex-direction:column}.info-label{font-size:12px;color:#6b7280}.info-value{font-size:16px;font-weight:600;color:#1f2937}.notes-section{background:#fffbeb;padding:16px;border-radius:12px;border:1px solid #fcd34d}.notes-section h4{margin:0 0 8px;font-size:14px;color:#92400e}.notes-section p{margin:0;color:#78350f;font-size:14px}.recent-checks-preview h4{margin:0 0 12px;font-size:16px;color:#374151}.checks-list{display:flex;flex-direction:column;gap:8px}.check-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#f9fafb;border-radius:8px}.check-date{font-size:14px;color:#374151;min-width:100px}.check-ripeness{font-weight:600;font-size:16px}.check-phase{font-size:12px;color:#6b7280;background:#e5e7eb;padding:2px 8px;border-radius:4px;text-transform:capitalize}.check-phase-badge{font-size:14px;font-weight:600;color:#374151;background:#f3f4f6;padding:4px 12px;border-radius:6px;text-transform:capitalize}.check-circumference{font-size:12px;color:#6b7280}.quick-check-btn{background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.quick-check-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4ade804d}.history-tab h3{margin:0 0 16px;font-size:18px;color:#1f2937}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{padding:14px 16px;background:#f9fafb;border-radius:12px;border:1px solid #e5e7eb}.history-date{font-size:14px;font-weight:500;color:#374151;margin-bottom:8px}.history-details{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.history-ripeness{padding:4px 10px;border-radius:6px;font-weight:600}.history-phase{font-size:12px;color:#6b7280;background:#e5e7eb;padding:4px 10px;border-radius:6px;text-transform:capitalize}.history-tag{font-size:12px;color:#6b7280;background:#e5e7eb;padding:4px 10px;border-radius:6px}.history-notes{margin:10px 0 0;font-size:13px;color:#6b7280;padding-top:10px;border-top:1px solid #e5e7eb}.history-empty{text-align:center;padding:32px;color:#6b7280}.photo-lightbox{position:fixed;inset:0;background:#000000e6;z-index:1100;display:flex;align-items:center;justify-content:center;padding:20px}.lightbox-content{position:relative;max-width:90vw;max-height:90vh}.lightbox-content img{max-width:100%;max-height:80vh;border-radius:8px;display:block}.lightbox-close{position:absolute;top:-40px;right:0;width:36px;height:36px;border-radius:50%;background:#fff3;border:none;color:#fff;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.lightbox-caption{text-align:center;color:#fff;margin-top:16px}@media (max-width: 768px){.tree-detail{border-radius:16px 16px 0 0;max-height:90vh}.detail-header{padding:16px;flex-direction:column;gap:16px}.close-detail-btn{align-self:flex-end}.detail-tabs{padding:0 16px}.tab-button{padding:12px 14px;font-size:13px}.detail-content{padding:16px}.info-cards{grid-template-columns:1fr}}:root{--nav-height: 64px}.app-v2{min-height:100vh;background-color:#f9fafb;padding-bottom:calc(var(--nav-height) + 16px + env(safe-area-inset-bottom,0px))}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.loading-icon{font-size:64px;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.error-banner{background-color:#fee;border-left:4px solid #ef4444;color:#dc2626;padding:1rem;margin:1rem;border-radius:8px;display:flex;justify-content:space-between;align-items:center}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#dc2626;padding:0;width:30px;height:30px}.success-toast{position:fixed;top:100px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;padding:12px 24px;border-radius:8px;font-weight:500;box-shadow:0 4px 12px #4ade804d;z-index:1100;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.app-main{padding:1.5rem;max-width:1200px;margin:0 auto}.empty-state{text-align:center;padding:60px 20px;background:#fff;border-radius:16px;box-shadow:0 2px 8px #00000014;margin-top:40px}.empty-icon{font-size:80px;margin-bottom:24px}.empty-state h2{margin:0 0 12px;color:#1f2937}.empty-state p{color:#6b7280;margin:0 0 32px;font-size:18px}.btn-primary{background:linear-gradient(135deg,#4ade80,#22c55e);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary.large{padding:16px 32px;font-size:18px}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #4ade804d}.trees-section{margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{margin:0;color:#1f2937}.btn-add{background:#fff;color:#22c55e;border:2px solid #22c55e;padding:8px 16px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.btn-add:hover{background:#22c55e;color:#fff}.trees-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.harvest-alert{background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;padding:24px;margin-bottom:32px}.harvest-alert h2{margin:0 0 16px;color:#92400e}.harvest-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.harvest-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 4px #0000001a}.harvest-card h3{margin:0 0 8px;font-size:16px;color:#1f2937}.harvest-card .ripeness{font-size:24px;font-weight:700;color:#16a34a;margin:0}.harvest-card .days{font-size:14px;color:#92400e;margin:4px 0 0}.activity-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 8px #00000014}.activity-section h2{margin:0 0 20px;color:#1f2937}.activity-list{display:flex;flex-direction:column;gap:16px}.activity-item{display:flex;align-items:center;gap:16px;padding:12px;background:#f9fafb;border-radius:8px}.activity-icon{width:40px;height:40px;background:#4ade8033;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#22c55e;font-size:20px;flex-shrink:0}.activity-details p{margin:0}.activity-meta{font-size:14px;color:#6b7280;margin-top:4px!important}.map-section{position:fixed;inset:0 0 80px;overflow:hidden;z-index:1}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e5e7eb;display:flex;justify-content:space-around;height:calc(var(--nav-height) + 16px);padding:8px 0 calc(16px + env(safe-area-inset-bottom,0px)) 0;z-index:1000}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px;background:none;border:none;color:#9ca3af;cursor:pointer;transition:all .2s}.nav-item.active{color:#22c55e}.nav-icon{font-size:24px}.nav-item span:last-child{font-size:12px;font-weight:500}@media (max-width: 768px){.app-main{padding:1rem}.trees-grid,.harvest-cards{grid-template-columns:1fr}.section-header{margin-bottom:16px}.nav-item{padding:10px 4px;min-height:56px}.nav-icon{font-size:22px}.nav-item span:last-child{font-size:11px}}@media (max-width: 390px){.app-main{padding:.75rem}.section-header h2{font-size:18px}.btn-add{padding:6px 12px;font-size:14px}.nav-icon{font-size:20px}.nav-item span:last-child{font-size:10px}}@media (pointer: coarse){.btn-primary,.btn-secondary,.btn-add{min-height:44px}}
