@import "https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;1,9..40,400&display=swap";:root{--green-deep:#1a2e1a;--green-dark:#243d24;--green-mid:#3a6b35;--green-light:#6aab5e;--green-pale:#c8e6c0;--green-wash:#f0f7ee;--amber:#d48c2a;--amber-light:#f5c06a;--red:#c0392b;--text-primary:#1a2e1a;--text-muted:#5a7a5a;--border:#d8ead5;--surface:#fff;--surface-2:#f7fbf5;--radius:12px;--radius-sm:8px;--shadow:0 2px 16px #1a2e1a14;--shadow-md:0 4px 32px #1a2e1a1f;--font-display:"Syne", sans-serif;--font-body:"DM Sans", sans-serif;--header-h:60px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-tap-highlight-color:transparent;font-size:16px}body{font-family:var(--font-body);color:var(--text-primary);background:var(--green-wash);background-image:radial-gradient(at 20% 0,#6aab5e1f 0%,#0000 60%),radial-gradient(at 80% 100%,#3a6b3514 0%,#0000 50%);min-height:100vh}button{cursor:pointer;font-family:var(--font-body);background:0 0;border:none}input,textarea,select{font-family:var(--font-body)}a{color:inherit;text-decoration:none}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1;width:100%;max-width:700px;margin:0 auto;padding:24px 16px 40px}.header{background:var(--green-deep);z-index:100;position:sticky;top:0;box-shadow:0 2px 20px #0003}.header-inner{max-width:700px;height:var(--header-h);justify-content:space-between;align-items:center;margin:0 auto;padding:0 16px;display:flex}.logo{color:#fff;align-items:center;gap:8px;display:flex}.logo-icon{font-size:22px}.logo-text{font-family:var(--font-display);letter-spacing:-.5px;font-size:18px;font-weight:800}.logo-sub{color:var(--green-pale);opacity:.7;letter-spacing:.5px;margin-top:1px;font-size:11px}.header-nav{align-items:center;gap:8px;display:flex}.nav-btn{color:#ffffffbf;border-radius:20px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s}.nav-btn:hover{color:#fff;background:#ffffff1a}.nav-btn.active{color:#fff;background:#ffffff26}.nav-btn.primary{background:var(--green-light);color:#fff;font-weight:600}.nav-btn.primary:hover{background:#7cc070}.btn{border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-primary);background:#fff;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover{border-color:var(--green-light);background:var(--green-wash)}.btn-primary{background:var(--green-mid);color:#fff;border-color:var(--green-mid)}.btn-primary:hover{background:var(--green-light);border-color:var(--green-light)}.btn-danger{color:var(--red);border-color:#f5c6c3}.btn-danger:hover{background:#fff5f5}.btn-sm{padding:6px 12px;font-size:12px}.btn-block{justify-content:center;width:100%;padding:12px;font-size:15px}.btn:disabled{opacity:.5;cursor:not-allowed}.card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.dashboard-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.page-title{font-family:var(--font-display);color:var(--green-deep);letter-spacing:-.5px;font-size:26px;font-weight:800}.page-sub{color:var(--text-muted);margin-top:3px;font-size:14px}.online-dot{font-size:12px;font-weight:500}.online-dot.online{color:var(--green-mid)}.online-dot.offline{color:var(--text-muted)}.lots-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.lots-grid--small{opacity:.7}.lot-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);padding:16px;transition:all .18s}.lot-card:hover{border-color:var(--green-light);box-shadow:var(--shadow-md);transform:translateY(-2px)}.lot-card--archived{opacity:.6}.lot-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.lot-card-title h3{font-family:var(--font-display);font-size:17px;font-weight:700}.lot-card-variete{color:var(--text-muted);font-size:12px}.day-counter{font-family:var(--font-display);background:var(--green-wash);color:var(--green-mid);border-radius:20px;padding:4px 10px;font-size:15px;font-weight:800}.lot-card-body{flex-direction:column;gap:8px;margin-bottom:12px;display:flex}.lot-card-footer{align-items:center;gap:12px;display:flex}.lot-card-meta{color:var(--text-muted);font-size:12px}.lot-card-arrow{color:var(--green-mid);margin-left:auto;font-size:16px}.status-badge{background:var(--green-wash);color:var(--green-dark);border:1px solid var(--green-pale);border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.status-badge--floraison{color:#b5267a;background:#fff0f8;border-color:#f5c0e0}.status-badge--séchage{color:#b07020;background:#fff8ec;border-color:#f0d8a0}.status-badge--terminé{color:#666;background:#f0f0f0;border-color:#ddd}.progress-bar{background:var(--green-pale);border-radius:4px;height:8px;overflow:hidden}.progress-bar--small{height:5px}.progress-fill{background:linear-gradient(90deg, var(--green-mid), var(--green-light));border-radius:4px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.back-btn{color:var(--text-muted);align-items:center;gap:4px;margin-bottom:12px;padding:6px 0;font-size:13px;display:inline-flex}.back-btn:hover{color:var(--green-mid)}.lot-header{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px;padding:20px}.lot-title-row{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.lot-name{font-family:var(--font-display);font-size:24px;font-weight:800}.lot-meta{color:var(--text-muted);margin-top:3px;font-size:13px}.lot-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:flex}.lot-stats{align-items:center;gap:16px;display:flex}.day-badge{background:var(--green-deep);color:#fff;border-radius:var(--radius-sm);flex-direction:column;align-items:center;min-width:64px;padding:10px 16px;display:flex}.day-number{font-family:var(--font-display);font-size:22px;font-weight:800;line-height:1}.day-label{opacity:.7;letter-spacing:.5px;font-size:11px}.stage-info{flex-direction:column;flex:1;gap:8px;display:flex}.stage-top{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.stage-btn{cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;display:flex}.stage-select{border:1.5px solid var(--green-light);border-radius:6px;padding:4px 8px;font-size:13px}.stage-next{color:var(--text-muted);font-size:12px}.tabs{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);gap:2px;margin-bottom:16px;padding:4px;display:flex}.tab{border-radius:var(--radius-sm);color:var(--text-muted);flex:1;padding:9px 12px;font-size:13px;font-weight:500;transition:all .15s}.tab:hover{background:var(--green-wash);color:var(--text-primary)}.tab.active{background:var(--green-deep);color:#fff}.tab-content{flex-direction:column;gap:12px;display:flex}.entry-form{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:10px;padding:14px;display:flex}.entry-type-row{flex-wrap:wrap;gap:6px;display:flex}.type-chip{background:var(--surface-2);border:1.5px solid var(--border);color:var(--text-muted);border-radius:16px;padding:5px 12px;font-size:12px;font-weight:500;transition:all .12s}.type-chip.active{background:var(--green-deep);color:#fff;border-color:var(--green-deep)}.entry-input-row{align-items:flex-end;gap:8px;display:flex}.entry-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);resize:none;flex:1;padding:10px 12px;font-size:14px;transition:border .15s}.entry-input:focus{border-color:var(--green-light);outline:none}.journal-list{flex-direction:column;gap:8px;display:flex}.journal-entry{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);align-items:flex-start;gap:10px;padding:12px;transition:all .12s;display:flex}.journal-entry--arrosage{border-left:3px solid #4db8e8}.journal-entry--alerte{border-left:3px solid var(--amber);background:#fffdf5}.journal-entry--traitement{border-left:3px solid #9b59b6}.entry-icon{flex-shrink:0;margin-top:1px;font-size:18px}.entry-body{flex:1}.entry-text{margin-bottom:4px;font-size:14px;line-height:1.5}.entry-date{color:var(--text-muted);font-size:11px}.entry-delete{color:var(--text-muted);opacity:.4;flex-shrink:0;padding:0 4px;font-size:18px;line-height:1;transition:opacity .12s}.entry-delete:hover{opacity:1;color:var(--red)}.photo-upload-area{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;color:var(--text-muted);justify-content:center;align-items:center;gap:10px;padding:24px;font-size:14px;transition:all .15s;display:flex}.photo-upload-area:hover{border-color:var(--green-light);background:var(--green-wash)}.upload-icon{font-size:24px}.photo-grid{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.photo-item{aspect-ratio:1;border-radius:var(--radius-sm);position:relative;overflow:hidden}.photo-thumb{object-fit:cover;cursor:pointer;width:100%;height:100%;display:block}.photo-overlay{opacity:0;background:linear-gradient(#0000,#00000080);justify-content:space-between;align-items:flex-end;padding:6px;transition:opacity .15s;display:flex;position:absolute;bottom:0;left:0;right:0}.photo-item:hover .photo-overlay{opacity:1}.photo-date{color:#fff;font-size:10px}.photo-delete{color:#fff;font-size:18px;line-height:1}.photo-modal{z-index:1000;background:#000000d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.photo-modal-inner{background:var(--surface);border-radius:var(--radius);width:100%;max-width:500px;padding:16px}.photo-full{border-radius:var(--radius-sm);width:100%;margin-bottom:10px}.photo-legende{margin-bottom:4px;font-weight:600}.photo-modal-date{color:var(--text-muted);margin-bottom:12px;font-size:12px}.modal-close{width:100%}.section-label{font-family:var(--font-display);margin-bottom:12px;font-size:15px;font-weight:700}.suggestions-list{flex-direction:column;gap:10px;list-style:none;display:flex}.suggestion-item{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);gap:12px;padding:14px;display:flex}.suggestion-icon{flex-shrink:0;font-size:22px}.suggestion-item strong{margin-bottom:3px;font-size:14px;display:block}.suggestion-item p{color:var(--text-muted);font-size:13px}.lot-form,.login-form{flex-direction:column;gap:16px;display:flex}.form-row{flex-direction:column;gap:6px;display:flex}.form-row--half{flex-direction:row;gap:12px}.form-row--half>div{flex-direction:column;flex:1;gap:6px;display:flex}.form-label{color:var(--text-primary);font-size:13px;font-weight:600}.form-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;padding:10px 12px;font-size:14px;transition:border .15s}.form-input:focus{border-color:var(--green-light);outline:none}.form-textarea{resize:vertical}.stage-picker{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.stage-option{border-radius:var(--radius-sm);border:1.5px solid var(--border);color:var(--text-muted);flex-direction:column;align-items:center;gap:4px;padding:10px 8px;font-size:12px;font-weight:500;transition:all .12s;display:flex}.stage-option:hover{border-color:var(--green-light);background:var(--green-wash)}.stage-option.active{border-color:var(--green-mid);background:var(--green-wash);color:var(--green-deep);font-weight:700}.stage-option-icon{font-size:20px}.create-lot{max-width:500px;margin:0 auto}.login-wrapper{justify-content:center;align-items:center;min-height:60vh;padding:20px;display:flex}.login-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);width:100%;max-width:380px;box-shadow:var(--shadow-md);text-align:center;padding:32px}.login-logo{margin-bottom:10px;font-size:48px}.login-title{font-family:var(--font-display);margin-bottom:4px;font-size:26px;font-weight:800}.login-sub{color:var(--text-muted);margin-bottom:24px;font-size:13px}.login-form{text-align:left}.alert{border-radius:var(--radius-sm);margin-bottom:16px;padding:12px 14px;font-size:13px}.alert-warning{border:1px solid var(--amber-light);color:#8a5a00;background:#fff8e6}.alert-error{color:var(--red);background:#fff0ef;border:1px solid #f5b5b0}.empty-state{text-align:center;background:var(--surface);border:1.5px dashed var(--border);border-radius:var(--radius);padding:60px 20px}.empty-icon{margin-bottom:12px;font-size:48px}.empty-state h3{font-family:var(--font-display);margin-bottom:6px;font-size:18px;font-weight:700}.empty-state p{color:var(--text-muted);margin-bottom:20px;font-size:14px}.empty-journal,.empty-photos{text-align:center;color:var(--text-muted);padding:30px;font-size:14px}.archived-section{margin-top:32px}.section-title{font-family:var(--font-display);color:var(--text-muted);margin-bottom:14px;font-size:16px;font-weight:700}.skeleton{background:linear-gradient(90deg, var(--green-pale) 25%, var(--green-wash) 50%, var(--green-pale) 75%);border-radius:var(--radius);background-size:200% 100%;height:140px;animation:1.4s infinite shimmer}.skeleton-entry{height:72px}.loading-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.loading-list{flex-direction:column;gap:8px;display:flex}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.not-found{text-align:center;padding:60px 20px}@media (width<=480px){.main-content{padding:16px 12px 32px}.lot-title-row{flex-direction:column}.lot-actions{justify-content:flex-start}.lots-grid{grid-template-columns:1fr}.photo-grid,.stage-picker{grid-template-columns:repeat(2,1fr)}.form-row--half{flex-direction:column}.lot-stats{flex-direction:column;align-items:stretch}.day-badge{flex-direction:row;align-items:center;gap:8px}}
