
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html{height:100%;-webkit-text-size-adjust:100%;}
body{font-family:'Plus Jakarta Sans',-apple-system,sans-serif;height:100%;overflow:hidden;background:#F2F2F7;color:#1C1C1E;-webkit-font-smoothing:antialiased;font-size:calc(16px * var(--font-scale));}

:root{
  --green:#34C759;--green-dark:#248A3D;--green-soft:rgba(52,199,89,0.12);
  --font-scale: 1;
  --blue:#007AFF;--orange:#FF9500;--red:#FF3B30;--purple:#AF52DE;
  --label:#1C1C1E;--label2:#3C3C43CC;--label3:#3C3C4399;--label4:#3C3C432E;
  --bg:#F2F2F7;--bg2:#FFFFFF;--bg3:#F2F2F7;
  --fill:#78788033;--fill2:#78788028;--separator:rgba(60,60,67,0.12);
  --shadow-sm:0 1px 3px rgba(0,0,0,0.06),0 1px 2px rgba(0,0,0,0.04);
  --shadow-md:0 4px 16px rgba(0,0,0,0.08),0 1px 4px rgba(0,0,0,0.04);
  --shadow-lg:0 16px 48px rgba(0,0,0,0.18),0 4px 16px rgba(0,0,0,0.10);
  --radius-sm:10px;--radius:16px;--radius-lg:22px;
  --tab-h:83px;--nav-h:56px;
  --spring:cubic-bezier(0.34,1.56,0.64,1);--ease-out:cubic-bezier(0.4,0,0.2,1);
}

#app{position:fixed;inset:0;display:flex;flex-direction:column;overflow:hidden;max-width:430px;margin:0 auto;background:var(--bg);}

/* NAV BAR */
.nav-bar{height:calc(var(--nav-h) + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px);background:rgba(242,242,247,0.85);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:0.5px solid var(--separator);display:flex;align-items:center;padding-left:8px;padding-right:8px;position:relative;z-index:50;flex-shrink:0;transition:background .3s ease;}
.nav-bar.scrolled{background:rgba(242,242,247,0.95);}
.nav-title{font-size:17px;font-weight:600;letter-spacing:-0.4px;color:var(--label);position:absolute;left:50%;transform:translateX(-50%);opacity:0;transition:opacity .2s ease;white-space:nowrap;}
.nav-title.visible{opacity:1;}
.nav-left,.nav-right{display:flex;gap:4px;align-items:center;}
.nav-right{margin-left:auto;}
.nav-btn{width:36px;height:36px;background:var(--fill);border:none;border-radius:50%;color:var(--blue);font-size:17px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s var(--spring),background .15s ease;}
.nav-btn:active{transform:scale(0.88);background:var(--fill2);}
.nav-btn.green{color:var(--green-dark);}
.nav-btn.gray{color:var(--label3);}

/* SCROLL */
.scroll-area{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:var(--tab-h);}
.scroll-area::-webkit-scrollbar{display:none;}

/* SECTIONS */
.section{display:none;}
.section.active{display:block;animation:sIn .28s var(--ease-out);}
@keyframes sIn{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

/* LARGE TITLE */
.large-title-wrap{padding:8px 20px 12px;}
.large-title{font-size:34px;font-weight:800;letter-spacing:-1px;color:var(--label);line-height:1.1;}
.large-title span{color:var(--green);}
.large-subtitle{font-size:15px;color:var(--label3);font-weight:400;margin-top:4px;letter-spacing:-0.2px;}

/* GROUPED LIST */
.section-block{margin:0 16px 24px;}
.section-block-header{font-size:13px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--label3);padding:0 4px 8px;line-height:1;}
.list-card{background:var(--bg2);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);}
.list-row{display:flex;align-items:center;padding:13px 16px;gap:12px;cursor:pointer;transition:background .12s ease;position:relative;min-height:52px;}
.list-row:not(:last-child)::after{content:'';position:absolute;left:56px;right:0;bottom:0;height:.5px;background:var(--separator);}
.list-row:active{background:var(--fill2);}

/* ─── PLANT CARD ─── */
.plant-card{background:var(--bg2);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .18s var(--spring),box-shadow .18s ease;margin:0 16px 12px;position:relative;overflow:hidden;display:flex;flex-direction:column;}
.plant-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),#5AC8FA);}
.plant-card:active{transform:scale(0.975);box-shadow:none;}
.plant-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.plant-names{flex:1;min-width:0;}
.plant-name{font-size:18px;font-weight:700;letter-spacing:-0.5px;color:var(--label);line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.plant-sci{font-size:13px;color:var(--label3);margin-top:2px;font-style:italic;}
.plant-card-right{display:flex;align-items:center;gap:10px;flex-shrink:0;}
.plant-type-pill{font-size:11px;font-weight:600;padding:4px 10px;border-radius:20px;background:var(--green-soft);color:var(--green-dark);max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.plant-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px;}
.meta-chip{font-size:12px;font-weight:500;padding:4px 10px;border-radius:20px;background:var(--bg3);color:var(--label2);display:flex;align-items:center;gap:4px;}
.plant-desc{font-size:14px;color:var(--label2);line-height:1.5;margin-top:8px;letter-spacing:-0.1px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.plant-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:4px;}
.health-ring{flex-shrink:0;}
.icon-btn{width:34px;height:34px;background:var(--fill);border:none;border-radius:50%;color:var(--label2);font-size:15px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s var(--spring),background .15s ease;}
.icon-btn:active{transform:scale(0.85);}
.icon-btn.red:active{background:rgba(255,59,48,.12);color:var(--red);}

/* ─── HEALTH SCORE RING ─── */
.health-ring{width:44px;height:44px;flex-shrink:0;position:relative;}
.health-ring svg{transform:rotate(-90deg);}
.health-ring .ring-bg{fill:none;stroke:#E5E5EA;stroke-width:3.5;}
.health-ring .ring-fg{fill:none;stroke-width:3.5;stroke-linecap:round;transition:stroke-dashoffset .8s var(--ease-out),stroke .4s ease;}
.health-score-text{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;letter-spacing:-0.5px;}
.focus-ring-interactive{cursor:pointer;}
.score-tooltip{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,0.12);padding:12px 14px;min-width:220px;z-index:200;text-align:left;}
.score-tooltip::before{content:'';position:absolute;top:-7px;right:12px;width:12px;height:12px;background:#fff;border-left:1px solid #e0e0e0;border-top:1px solid #e0e0e0;transform:rotate(45deg);}

/* ─── SEASONAL BANNER ─── */
.seasonal-banner{margin:0 16px 16px;background:linear-gradient(135deg,#1C3A1F,#2D5A32);border-radius:var(--radius-lg);padding:16px;position:relative;overflow:hidden;}
.seasonal-banner::after{content:'🌿';position:absolute;right:-8px;top:-8px;font-size:72px;opacity:.1;pointer-events:none;}
.sb-label{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:6px;}
.sb-title{font-size:18px;font-weight:800;letter-spacing:-.5px;color:white;line-height:1.2;}
.sb-tips{margin-top:10px;display:flex;flex-direction:column;gap:6px;}
.sb-tip{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:rgba(255,255,255,.85);line-height:1.4;}
.sb-tip-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;margin-top:5px;}
.sb-empty{font-size:13px;color:rgba(255,255,255,.5);font-style:italic;}

/* JOURNAL CARD */
.journal-card{background:var(--bg2);border-radius:var(--radius-lg);padding:14px 16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .15s var(--spring);margin:0 16px 10px;}
.journal-card:active{transform:scale(0.975);}
.jc-top{display:flex;align-items:center;justify-content:space-between;}
.jc-icon{width:36px;height:36px;border-radius:10px;background:var(--green-soft);color:var(--green-dark);display:flex;align-items:center;justify-content:center;font-size:18px;}
.jc-activity{font-size:16px;font-weight:600;letter-spacing:-.3px;color:var(--label);}
.jc-date{font-size:12px;color:var(--label3);font-weight:500;}
.plant-desc{font-size:14px;color:var(--label2);line-height:1.5;margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* ─── STREAK BADGE ─── */
.streak-banner{margin:0 16px 16px;background:var(--bg2);border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:14px;box-shadow:var(--shadow-sm);}
.streak-flame{font-size:36px;animation:flicker 2s ease infinite;}
@keyframes flicker{0%,100%{transform:scale(1) rotate(-2deg);}50%{transform:scale(1.1) rotate(2deg);}}
.streak-info{flex:1;}
.streak-num{font-size:28px;font-weight:800;letter-spacing:-1px;color:var(--orange);}
.streak-label{font-size:13px;color:var(--label3);font-weight:500;margin-top:1px;}
.streak-dots{display:flex;gap:4px;margin-top:6px;}
.sdot{width:8px;height:8px;border-radius:50%;background:var(--fill);}
.sdot.active{background:var(--orange);}

/* KNOWLEDGE */
.k-card{background:var(--bg2);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);cursor:pointer;margin:0 16px 10px;transition:transform .15s var(--spring);}
.k-card:active{transform:scale(0.975);}
.k-topic{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:4px;}
.k-title{font-size:16px;font-weight:600;letter-spacing:-.3px;color:var(--label);line-height:1.3;}
.k-source{font-size:13px;color:var(--label3);margin-top:3px;}

/* PRODOTTO */
.prod-card{background:var(--bg2);border-radius:var(--radius);box-shadow:var(--shadow-sm);margin:0 16px 10px;display:flex;align-items:center;gap:12px;padding:14px 16px;}

/* CALENDAR */
.month-strip{display:flex;overflow-x:auto;gap:6px;padding:4px 16px 12px;scrollbar-width:none;}
.month-strip::-webkit-scrollbar{display:none;}
.month-pill{flex-shrink:0;font-size:14px;font-weight:600;letter-spacing:-.2px;padding:7px 16px;border-radius:20px;border:none;cursor:pointer;background:var(--fill);color:var(--label2);transition:background .15s ease,color .15s ease,transform .15s var(--spring);}
.month-pill.active{background:var(--green);color:white;}
.month-pill:active{transform:scale(0.92);}
.seg-wrap{padding:0 16px 10px;}
.seg-ctrl{display:flex;background:var(--fill);border-radius:10px;padding:2px;}
.seg-btn{flex:1;padding:6px 4px;border:none;border-radius:8px;font-size:13px;font-weight:600;color:var(--label2);background:transparent;cursor:pointer;transition:background .2s ease,color .2s ease,box-shadow .2s ease;letter-spacing:-.1px;}
.seg-btn.active{background:var(--bg2);color:var(--label);box-shadow:0 2px 8px rgba(0,0,0,.10),0 1px 2px rgba(0,0,0,.06);}

/* ─── CAL CARD with swipe ─── */
.cal-card-wrap{margin:0 16px 10px;position:relative;overflow:hidden;border-radius:var(--radius);}
.cal-card-swipe-bg{position:absolute;inset:0;background:var(--green);display:flex;align-items:center;padding-left:20px;border-radius:var(--radius);}
.cal-card-swipe-bg.red-bg{background:var(--red);align-items:center;padding-left:0;padding-right:20px;justify-content:flex-end;}
.swipe-icon{font-size:24px;color:white;}
.cal-card{background:var(--bg2);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .15s ease;position:relative;z-index:1;display:flex;align-items:flex-start;gap:12px;touch-action:pan-y;}
.cal-card.swiped{transform:translateX(72px);}
.cal-card.swiped-left{transform:translateX(-72px);}
.cal-status{width:12px;height:12px;border-radius:50%;margin-top:4px;flex-shrink:0;transition:background .3s ease;}
.s-todo{background:#C7C7CC;}.s-doing{background:var(--orange);}.s-done{background:var(--green);}.s-skip{background:#C7C7CC;opacity:.4;}
.cal-body{flex:1;min-width:0;}
.cal-title{font-size:16px;font-weight:600;letter-spacing:-.3px;color:var(--label);}
.cal-note{font-size:13px;color:var(--label3);margin-top:3px;line-height:1.4;}

/* ─── GLOBAL SEARCH ─── */
.search-overlay{position:fixed;inset:0;z-index:600;background:rgba(242,242,247,0);pointer-events:none;transition:background .3s ease;display:flex;flex-direction:column;max-width:430px;margin:0 auto;}
.search-overlay.open{background:rgba(242,242,247,1);pointer-events:all;}
.search-overlay.open .search-bar-wrap{transform:translateY(0);opacity:1;}
.search-overlay.open .search-results{opacity:1;transform:translateY(0);}
.search-bar-wrap{padding:calc(env(safe-area-inset-top,0px) + 12px) 16px 8px;display:flex;align-items:center;gap:10px;background:rgba(242,242,247,0.95);backdrop-filter:blur(20px);transform:translateY(-20px);opacity:0;transition:transform .3s var(--spring),opacity .25s ease;flex-shrink:0;}
.search-input-wrap{flex:1;display:flex;align-items:center;gap:8px;background:white;border-radius:12px;padding:10px 14px;box-shadow:var(--shadow-md);}
.search-input-wrap .si{font-size:16px;color:var(--label3);}
.search-input{flex:1;border:none;outline:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:500;color:var(--label);background:transparent;}
.search-input::placeholder{color:var(--label3);}
.search-cancel{font-size:16px;font-weight:600;color:var(--blue);cursor:pointer;white-space:nowrap;padding:8px 4px;}
.search-results{flex:1;overflow-y:auto;padding:8px 16px;opacity:0;transform:translateY(10px);transition:opacity .3s ease .1s,transform .3s var(--spring) .1s;}
.search-section-header{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--label3);padding:12px 4px 6px;}
.search-item{background:var(--bg2);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:6px;cursor:pointer;transition:transform .1s ease;display:flex;align-items:center;gap:10px;}
.search-item:active{transform:scale(0.98);}
.search-item-icon{width:32px;height:32px;border-radius:8px;background:var(--green-soft);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.search-item-title{font-size:15px;font-weight:600;color:var(--label);letter-spacing:-.2px;}
.search-item-sub{font-size:12px;color:var(--label3);margin-top:2px;}
.search-highlight{color:var(--green);background:var(--green-soft);border-radius:3px;padding:0 2px;}
.search-empty{text-align:center;padding:40px 20px;color:var(--label3);font-size:15px;}

/* ─── SHARE CARD ─── */
.share-overlay{position:fixed;inset:0;z-index:700;background:rgba(0,0,0,0);pointer-events:none;transition:background .4s ease;display:flex;align-items:flex-end;justify-content:center;max-width:430px;margin:0 auto;}
.share-overlay.open{background:rgba(0,0,0,0.7);pointer-events:all;}
.share-card-container{transform:translateY(100%);transition:transform .42s var(--spring);width:100%;padding:0 20px calc(env(safe-area-inset-bottom,0px) + 20px);}
.share-overlay.open .share-card-container{transform:translateY(0);}
.share-card{border-radius:var(--radius-lg);overflow:hidden;background:white;box-shadow:var(--shadow-lg);}
.share-card-hero{background:linear-gradient(135deg,#1C3A1F 0%,#2D5A32 50%,#1C3A1F 100%);padding:28px 24px 22px;position:relative;overflow:hidden;}
.share-card-bg-leaf{position:absolute;right:-20px;bottom:-20px;font-size:120px;opacity:.08;pointer-events:none;transform:rotate(20deg);}
.sc-label{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:10px;}
.sc-name{font-size:28px;font-weight:800;letter-spacing:-.8px;color:white;line-height:1.1;}
.sc-sci{font-size:15px;color:rgba(255,255,255,.55);margin-top:5px;font-style:italic;}
.sc-breve{font-size:14px;color:rgba(255,255,255,.75);margin-top:12px;line-height:1.5;}
.share-card-body{padding:20px 24px;}
.sc-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px;}
.sc-field{background:#F2F2F7;border-radius:10px;padding:10px 12px;}
.sc-field-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--label3);margin-bottom:3px;}
.sc-field-val{font-size:14px;font-weight:600;color:var(--label);}
.sc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:4px;}
.sc-watermark{font-size:11px;color:var(--label3);display:flex;align-items:center;gap:4px;}
.sc-health{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--green-dark);}
.share-actions{display:flex;gap:10px;margin-top:12px;}
.share-close-btn{flex:1;padding:14px;border:1px solid #34C759;border-radius:var(--radius-sm);background:#ffffff;color:#1C1C1E;font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;}
.share-screenshot-btn{flex:2;padding:14px;border:none;border-radius:var(--radius-sm);background:var(--green);color:white;font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:700;cursor:pointer;transition:transform .15s var(--spring);}
.share-screenshot-btn:active{transform:scale(0.97);}

/* ─── CONFETTI ─── */
#confetti-canvas{position:fixed;inset:0;z-index:800;pointer-events:none;max-width:430px;margin:0 auto;}

/* ─── SETTINGS SHEET ─── */
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;cursor:pointer;transition:background .12s ease;}
.settings-row:active{background:var(--fill2);}
.settings-row-left{display:flex;align-items:center;gap:12px;}
.settings-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;}
.settings-label{font-size:16px;font-weight:500;color:var(--label);}
.settings-arrow{color:var(--label4);font-size:13px;font-weight:600;}

/* ─── DETAIL ─── */
.detail-view{position:fixed;inset:0;z-index:300;background:var(--bg);transform:translateX(100%);transition:transform .35s var(--ease-out);display:flex;flex-direction:column;max-width:430px;left:max(0px,calc((100vw - 430px)/2));}
.detail-view.open{transform:translateX(0);}
.detail-nav{height:calc(52px + env(safe-area-inset-top,0px));padding-top:env(safe-area-inset-top,0px);background:rgba(242,242,247,.88);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:.5px solid var(--separator);display:flex;align-items:center;gap:4px;padding-left:8px;padding-right:8px;flex-shrink:0;}
.detail-back{display:flex;align-items:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--green-dark);padding:6px 8px;border-radius:8px;font-size:16px;font-weight:600;transition:opacity .15s ease;}
.detail-back:active{opacity:.5;}
.detail-nav-title{flex:1;font-size:17px;font-weight:700;letter-spacing:-.4px;color:var(--label);text-align:center;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;padding:0 8px;}
.detail-edit{background:none;border:none;cursor:pointer;color:var(--blue);font-size:15px;font-weight:600;padding:6px 8px;}
.detail-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;}
.detail-hero{background:linear-gradient(160deg,#1C3A1F 0%,#2D5A32 100%);padding:24px 20px 22px;position:relative;overflow:visible;}
.detail-hero::after{content:none;}
.detail-hero-name{font-size:28px;font-weight:800;letter-spacing:-1px;color:white;line-height:1.15;}
.detail-hero-sci{font-size:15px;color:rgba(255,255,255,.6);margin-top:4px;font-style:italic;}
.detail-hero-desc{font-size:14px;color:rgba(255,255,255,.75);margin-top:10px;line-height:1.5;}
.detail-section{margin:20px 16px 0;}
.detail-section-title{font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--label3);margin-bottom:8px;}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.info-cell{background:var(--bg2);border-radius:var(--radius-sm);padding:10px 12px;box-shadow:var(--shadow-sm);}
.info-cell.full{grid-column:1/-1;}
.info-cell-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--label3);margin-bottom:3px;}
.info-cell-val{font-size:14px;color:var(--label);line-height:1.4;letter-spacing:-.1px;}
.detail-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;padding-bottom:100px;}
.dtag{font-size:13px;font-weight:500;padding:5px 12px;border-radius:20px;background:var(--fill);color:var(--label2);display:flex;align-items:center;gap:5px;}
.dtag.green{background:var(--green-soft);color:var(--green-dark);}

/* SHEET */
.sheet-overlay{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,0);pointer-events:none;transition:background .35s ease;display:flex;align-items:flex-end;justify-content:center;max-width:430px;margin:0 auto;}
.sheet-overlay.open{background:rgba(0,0,0,0.45);pointer-events:all;}
.sheet{background:var(--bg2);border-radius:20px 20px 0 0;width:100%;transform:translateY(100%);transition:transform .42s var(--spring);display:flex;flex-direction:column;max-height:94dvh;overflow:hidden;}
.sheet-overlay.open .sheet{transform:translateY(0);}
.sheet-handle{width:36px;height:4px;border-radius:2px;background:var(--label4);margin:10px auto 0;flex-shrink:0;}
.sheet-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;flex-shrink:0;}
.sheet-title{font-size:17px;font-weight:700;letter-spacing:-.4px;color:var(--label);}
.sheet-close{width:30px;height:30px;border-radius:50%;background:var(--fill);border:none;color:var(--label2);font-size:15px;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.sheet-body{flex:1;overflow-y:auto;padding:0 20px;-webkit-overflow-scrolling:touch;}
.sheet-footer{padding:12px 20px calc(12px + env(safe-area-inset-bottom,0px));border-top:.5px solid var(--separator);flex-shrink:0;}

/* FORM */
.form-section{font-size:12px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--label3);margin:20px 0 8px;padding:0 2px;}
.form-group{margin-bottom:14px;}
.form-label{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--label3);display:block;margin-bottom:6px;}
.form-ctrl{width:100%;padding:13px 14px;background:var(--bg3);border:none;border-radius:var(--radius-sm);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:400;color:var(--label);outline:none;transition:background .15s ease,box-shadow .15s ease;-webkit-appearance:none;}
.form-ctrl:focus{background:white;box-shadow:0 0 0 3px rgba(52,199,89,.2);}
.form-ctrl::placeholder{color:var(--label3);}
textarea.form-ctrl{min-height:80px;resize:none;}
.md-hint{font-size:11px;color:var(--label3);margin-top:4px;padding:0 2px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}

/* BUTTON */
.btn{width:100%;padding:15px;border-radius:var(--radius-sm);border:none;font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:700;letter-spacing:-.2px;cursor:pointer;transition:transform .15s var(--spring),opacity .15s ease;display:flex;align-items:center;justify-content:center;gap:6px;}
.btn:active{transform:scale(0.97);opacity:.85;}
.btn-green{background:var(--green);color:white;}
.btn-outline{background:var(--fill);color:var(--label);}

/* EMPTY */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 32px;text-align:center;gap:10px;}
.empty-icon{font-size:56px;filter:grayscale(.3);margin-bottom:4px;}
.empty-title{font-size:20px;font-weight:700;letter-spacing:-.5px;color:var(--label);}
.empty-body{font-size:15px;color:var(--label3);line-height:1.5;max-width:240px;letter-spacing:-.1px;}

/* FAB */
.fab{position:fixed;bottom:calc(var(--tab-h) + 16px);right:max(16px,calc((100vw - 430px)/2 + 16px));width:56px;height:56px;background:var(--green);border:none;border-radius:50%;box-shadow:0 4px 20px rgba(52,199,89,.45),0 2px 8px rgba(52,199,89,.3);color:white;font-size:28px;font-weight:300;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:200;transition:transform .2s var(--spring),box-shadow .2s ease;}
.fab:active{transform:scale(0.88);}

/* TAB BAR */
.tab-bar{height:var(--tab-h);padding-bottom:env(safe-area-inset-bottom,16px);background:rgba(249,249,249,.88);backdrop-filter:blur(24px) saturate(200%);-webkit-backdrop-filter:blur(24px) saturate(200%);border-top:.5px solid var(--separator);display:flex;align-items:flex-start;padding-top:8px;flex-shrink:0;z-index:50;}
.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;border:none;background:none;cursor:pointer;transition:transform .15s var(--spring);padding:0 2px;}
.tab-item:active{transform:scale(0.88);}
.tab-icon{font-size:23px;filter:grayscale(1) opacity(.5);transition:filter .15s ease,transform .2s var(--spring);}
.tab-item.active .tab-icon{filter:none;transform:scale(1.08);}
.tab-label{font-size:10px;font-weight:500;letter-spacing:.02em;color:var(--label3);transition:color .15s ease;white-space:nowrap;}
.tab-item.active .tab-label{color:var(--green-dark);font-weight:700;}

/* TOAST */
#toast{position:fixed;bottom:calc(var(--tab-h) + 72px);left:50%;transform:translateX(-50%) translateY(20px);background:rgba(30,30,30,.92);backdrop-filter:blur(12px);color:white;padding:10px 18px;border-radius:20px;font-size:14px;font-weight:500;z-index:900;opacity:0;pointer-events:none;white-space:nowrap;transition:opacity .25s ease,transform .25s var(--spring);}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ─── QUICK LOG (long press) ─── */
.quick-log-overlay{position:fixed;inset:0;z-index:500;pointer-events:none;display:flex;align-items:center;justify-content:center;max-width:430px;margin:0 auto;}
.quick-log-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .25s ease;}
.quick-log-overlay.open{pointer-events:all;}
.quick-log-overlay.open .quick-log-backdrop{background:rgba(0,0,0,.5);}
.quick-log-sheet{background:var(--bg2);border-radius:var(--radius-xl);padding:20px;width:calc(100% - 48px);max-width:360px;transform:scale(0.85);opacity:0;transition:transform .3s var(--spring),opacity .25s ease;}
.quick-log-overlay.open .quick-log-sheet{transform:scale(1);opacity:1;}
.ql-title{font-size:17px;font-weight:700;letter-spacing:-.4px;color:var(--label);margin-bottom:4px;}
.ql-plant{font-size:13px;color:var(--label3);margin-bottom:16px;}
.ql-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px;}
.ql-btn{background:var(--bg3);border:none;border-radius:var(--radius-sm);padding:12px 8px;font-size:20px;cursor:pointer;transition:transform .15s var(--spring),background .15s ease;display:flex;flex-direction:column;align-items:center;gap:4px;}
.ql-btn:active{transform:scale(0.92);background:var(--green-soft);}
.ql-btn span{font-size:11px;font-weight:600;color:var(--label2);}
.ql-cancel{width:100%;padding:13px;border:none;border-radius:var(--radius-sm);background:var(--fill);color:var(--label2);font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;font-weight:600;cursor:pointer;}

/* STATS CARDS */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin:0 16px 24px;}
.stat-card{background:var(--bg2);border-radius:var(--radius);padding:14px 12px;box-shadow:var(--shadow-sm);text-align:center;}
.stat-num{font-size:28px;font-weight:800;letter-spacing:-1px;color:var(--green-dark);}
.stat-lbl{font-size:11px;font-weight:600;color:var(--label3);margin-top:2px;letter-spacing:.02em;}

/* SPLASH */
#splash{position:fixed;inset:0;z-index:1000;background:white;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;transition:opacity .5s ease;}
#splash.out{opacity:0;pointer-events:none;}
.splash-app-icon{width:100px;height:100px;border-radius:24px;background:linear-gradient(145deg,#2ECC71,#27AE60);display:flex;align-items:center;justify-content:center;font-size:52px;box-shadow:0 8px 32px rgba(52,199,89,.35);animation:sBounce .8s var(--spring) .2s both;}
@keyframes sBounce{from{transform:scale(0);opacity:0;}to{transform:scale(1);opacity:1;}}
.splash-name{font-size:28px;font-weight:800;letter-spacing:-.8px;color:#1C1C1E;animation:sFadeUp .5s ease .6s both;}
.splash-sub{font-size:15px;color:#8E8E93;animation:sFadeUp .5s ease .75s both;}
/* ─── LOGIN SCREEN ─── */
#login-screen{
  position:fixed;inset:0;z-index:2000;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,#0F2817 0%,#1C3A1F 40%,#2D5A32 100%);
  padding:24px;
}
#login-screen.hidden{display:none;}
.login-card{
  background:white;border-radius:28px;padding:32px 28px 28px;
  width:100%;max-width:380px;
  box-shadow:0 24px 80px rgba(0,0,0,0.35);
}
.login-logo{
  width:72px;height:72px;border-radius:18px;
  background:transparent;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.login-title{font-size:26px;font-weight:800;letter-spacing:-.8px;color:#1C1C1E;text-align:center;margin-bottom:4px;}
.login-sub{font-size:15px;color:#8E8E93;text-align:center;margin-bottom:28px;}
.login-tabs{display:flex;background:#F2F2F7;border-radius:10px;padding:2px;margin-bottom:20px;}
.login-tab{flex:1;padding:8px;border:none;border-radius:8px;font-family:'Plus Jakarta Sans',sans-serif;font-size:14px;font-weight:600;color:#8E8E93;background:transparent;cursor:pointer;transition:all .2s ease;}
.login-tab.active{background:white;color:#1C1C1E;box-shadow:0 2px 8px rgba(0,0,0,.1);}
.login-form{display:flex;flex-direction:column;gap:12px;}
.login-input{
  padding:14px 16px;border:1.5px solid #E5E5EA;border-radius:12px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:15px;color:#1C1C1E;
  outline:none;transition:border-color .2s ease;
}
.login-input:focus{border-color:#34C759;}
.login-input::placeholder{color:#C7C7CC;}
.btn-login-email{
  padding:15px;border:none;border-radius:12px;background:#34C759;color:white;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:700;
  cursor:pointer;transition:transform .15s var(--spring),opacity .15s ease;margin-top:4px;
}
.btn-login-email:active{transform:scale(0.97);opacity:.9;}
.login-divider{display:flex;align-items:center;gap:12px;margin:4px 0;}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:#E5E5EA;}
.login-divider span{font-size:13px;color:#C7C7CC;font-weight:500;}
.login-forgot{text-align:center;margin-top:8px;}
.login-forgot a{font-size:13px;color:#34C759;font-weight:600;cursor:pointer;text-decoration:none;}
.login-error{font-size:13px;color:#FF3B30;font-weight:500;text-align:center;padding:8px 12px;background:rgba(255,59,48,.08);border-radius:8px;display:none;}
.login-error.show{display:block;}

/* ─── ACTIVITY CHIPS ─── */
.activity-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.act-chip{
  padding:6px 12px;border-radius:20px;border:1.5px solid var(--separator);
  background:var(--bg2);font-family:'Plus Jakarta Sans',sans-serif;
  font-size:13px;font-weight:600;color:var(--label2);cursor:pointer;
  transition:all .15s ease;white-space:nowrap;
}
.act-chip:active,.act-chip.active{
  background:var(--green-soft);border-color:var(--green);color:var(--green-dark);
}

/* ─── ESPOSIZIONE PICKER ─── */
.esp-picker{display:flex;gap:6px;margin-top:4px;}
.esp-btn{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:10px 4px;border-radius:12px;border:2px solid var(--separator);
  background:var(--bg2);cursor:pointer;font-family:'Plus Jakarta Sans',sans-serif;
  transition:all .15s ease;
}
.esp-btn span{font-size:11px;font-weight:600;color:var(--label3);}
.esp-btn:first-child{font-size:22px;}
.esp-btn:nth-child(2){font-size:22px;}
.esp-btn:last-child{font-size:22px;}
.esp-btn.active{border-color:var(--orange);background:rgba(255,149,0,.08);}
.esp-btn.active span{color:var(--orange);}

/* ─── FIORITURA MESI PICKER ─── */
.fior-picker{margin-top:4px;}
.fior-months{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;}
.fm-btn{
  border-radius:8px;border:none;
  background:var(--fill2);font-size:11px;font-weight:700;
  color:var(--label3);cursor:pointer;padding:6px 2px;
  transition:all .15s ease;white-space:nowrap;
}
.fm-btn.active{background:var(--green);color:white;}
.fm-btn:active{transform:scale(0.9);}
.fior-preview{
  margin-top:6px;font-size:12px;font-weight:600;
  color:var(--green-dark);text-align:center;min-height:18px;
}

/* ─── RELATION CHIPS IN FORM ─── */
.rel-piante-wrap{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:0;}
.rel-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px 6px 12px;border-radius:20px;background:var(--green-soft);color:var(--green-dark);font-size:13px;font-weight:600;}
.rel-chip-del{background:none;border:none;color:var(--green-dark);cursor:pointer;font-size:14px;padding:0;line-height:1;}

/* ─── PHOTO GALLERY ─── */
.photo-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px;}
.photo-thumb{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;background:var(--fill2);}
.photo-thumb img{width:100%;height:100%;object-fit:cover;cursor:pointer;}
.photo-thumb-del{position:absolute;top:4px;right:4px;background:rgba(0,0,0,.6);color:white;border:none;border-radius:50%;width:20px;height:20px;font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;}
.photo-add-btn{display:flex;align-items:center;justify-content:center;height:44px;border-radius:12px;border:2px dashed var(--separator);background:var(--bg2);cursor:pointer;font-size:14px;font-weight:600;color:var(--label3);}
.photo-add-btn:active{background:var(--fill2);}

/* ─── PHOTO LIGHTBOX ─── */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:9999;display:flex;align-items:center;justify-content:center;}
.lightbox img{max-width:95vw;max-height:90vh;object-fit:contain;border-radius:8px;}
.lightbox-close{position:absolute;top:16px;right:16px;color:white;font-size:28px;cursor:pointer;background:none;border:none;line-height:1;}

/* ─── RELATION CHIPS NAVIGABILI ─── */
.dtag{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s;}
.dtag:active{opacity:.7;}
.dtag.green{background:var(--green-soft);color:var(--green-dark);}
.dtag.blue{background:rgba(0,122,255,.1);color:#007AFF;}
.dtag.orange{background:rgba(255,149,0,.1);color:var(--orange);}

/* ─── PIANTE INLINE COUNTERS ─── */
.piante-counters{display:flex;gap:6px;flex-wrap:wrap;}
.pcounter{font-size:12px;font-weight:700;color:var(--label3);background:var(--fill2);padding:4px 8px;border-radius:12px;}

/* ─── FILTER PANEL ─── */
.filter-btn{padding:7px 12px;border-radius:10px;border:1.5px solid var(--separator);background:var(--bg2);font-size:13px;font-weight:600;color:var(--label2);cursor:pointer;white-space:nowrap;transition:all .15s;}
.filter-btn.active{background:var(--green-soft);border-color:var(--green);color:var(--green-dark);}
.filter-panel{background:var(--bg2);border-radius:14px;padding:14px;margin-top:8px;border:1px solid var(--separator);}
.filter-row{display:flex;align-items:center;gap:8px;margin-bottom:10px;}
.filter-label{font-size:12px;font-weight:700;color:var(--label3);width:64px;flex-shrink:0;}
.filter-chip{padding:5px 10px;border-radius:16px;border:1.5px solid var(--separator);background:var(--bg2);font-size:12px;font-weight:600;color:var(--label2);cursor:pointer;}
.filter-chip.active{background:var(--green-soft);border-color:var(--green);color:var(--green-dark);}
.btn-sm{padding:6px 14px;border-radius:10px;border:none;font-size:13px;font-weight:600;cursor:pointer;}

/* ─── MARKDOWN IN DETAIL ─── */
.md-bold{font-weight:700;}
.md-underline{text-decoration:underline;}

/* ─── PRODOTTO DETAIL ─── */
.prod-icon-circle{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--separator);}
.prod-icon-emoji{width:72px;height:72px;border-radius:50%;background:var(--fill2);display:flex;align-items:center;justify-content:center;font-size:32px;}

/* User avatar nella nav */
.user-avatar{
  width:32px;height:32px;border-radius:50%;
  background:var(--green-soft);border:2px solid var(--green);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;color:var(--green-dark);
  cursor:pointer;overflow:hidden;flex-shrink:0;
}
.user-avatar img{width:100%;height:100%;object-fit:cover;}

/* ─── IPAD / DESKTOP RESPONSIVE ──────────────────────────────
   ≥ 768px: sidebar sinistra + layout 2 colonne
   ─────────────────────────────────────────────────────────── */
@media (min-width: 768px) {
  body { background: #E5E5EA; overflow: auto; }

  #app {
    position: relative;
    max-width: none;
    width: 100%; height: 100vh;
    display: grid;
    grid-template-columns: 240px 1fr;
    grid-template-rows: 1fr;
    overflow: hidden;
  }

  /* SIDEBAR — colonna sinistra fissa (#9) */
  #sidebar {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    flex-direction: column;
    background: rgba(242,242,247,0.96);
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border-right: 0.5px solid var(--separator);
    position: fixed;
    top: 0;
    width: 240px;
    height: 100vh;
    max-height: 100vh;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    z-index: 50;
  }

  /* NAV BAR nella sidebar */
  .nav-bar {
    height: auto;
    padding: 24px 16px 12px;
    border-bottom: 0.5px solid var(--separator);
    flex-direction: column;
    align-items: flex-start;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    position: relative;
  }
  .nav-bar::before {
    content: none;
  }
  .nav-bar-brand {
    display: flex !important;
    align-items: center;
    gap: 8px;
    font-size: 19px; font-weight: 800; letter-spacing: -.5px;
    color: var(--green-dark);
    margin-bottom: 14px; width: 100%;
  }
  .nav-bar-brand img {
    width: 28px; height: 28px; border-radius: 8px; flex-shrink: 0;
  }
  .nav-left { flex-direction: row; width: 100%; margin-bottom: 0; }
  .nav-right { margin-left: 0; width: 100%; justify-content: flex-start; margin-top: 6px; }
  .nav-title { display: none; }

  /* TAB BAR → nav verticale */
  .tab-bar {
    position: static !important;
    height: auto;
    flex-direction: column;
    align-items: stretch;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border-top: none;
    padding: 8px 10px 20px;
    gap: 2px;
    flex: 1;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .tab-item {
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 12px;
    width: 100%;
    transition: background .15s ease, transform .1s var(--spring);
  }
  .tab-item.active { background: var(--green-soft); }
  .tab-item:active { transform: scale(0.98); background: var(--fill2); }
  .tab-icon { font-size: 20px; filter: grayscale(1) opacity(.45); }
  .tab-item.active .tab-icon { filter: none; transform: none; }
  .tab-label {
    font-size: 15px; font-weight: 600; letter-spacing: -.2px;
    color: var(--label2);
  }
  .tab-item.active .tab-label { color: var(--green-dark); }

  /* SCROLL AREA → colonna destra (#9 #2) */
  .scroll-area {
    grid-column: 2;
    grid-row: 1;
    padding-bottom: 120px;
    max-height: 100vh;
    overflow-y: auto;
    width: 100%;
  }

  /* PLANT GRID — 2 colonne */
  #piante-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 4px;
  }
  #piante-list .plant-card { margin: 0 12px 12px; }
  #piante-list .empty { grid-column: 1/-1; }

  /* JOURNAL GRID — 2 colonne */
  #journal-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 4px;
  }
  #journal-list .journal-card { margin: 0 12px 10px; }
  #journal-list .empty { grid-column: 1/-1; }

  /* KNOWLEDGE GRID — 2 colonne */
  #knowledge-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 4px;
  }
  #knowledge-list .k-card { margin: 0 12px 10px; }
  #knowledge-list .empty { grid-column: 1/-1; }

  /* CALENDARIO — più spazioso */
  .cal-card-wrap { margin: 0 20px 10px; }

  /* FAB */
  .fab { right: 32px; bottom: 32px; }

  /* DETAIL — pannello laterale */
  .detail-view {
    left: 240px !important;
    width: calc(100vw - 240px);
    max-width: none;
  }

  /* SHEET — più larga */
  .sheet { max-width: 560px; margin: 0 auto; }

  /* OVERLAYS — escludono sidebar */
  .search-overlay,
  .share-overlay,
  .quick-log-overlay {
    left: 240px;
    width: calc(100vw - 240px);
    max-width: none;
    margin: 0;
  }
  #confetti-canvas { left: 240px; width: calc(100vw - 240px); max-width: none; }

  /* LAYOUT TWEAKS */
  .seasonal-banner { margin: 0 20px 16px; }
  .stat-row { margin: 0 20px 24px; gap: 12px; }
  .large-title { font-size: 40px; }
  .large-title-wrap { padding: 24px 24px 16px; }
  .section-block { margin: 0 20px 24px; }

  /* SCROLLBAR visibile su desktop */
  .scroll-area::-webkit-scrollbar { display: block; width: 6px; }
  .scroll-area::-webkit-scrollbar-track { background: transparent; }
  .scroll-area::-webkit-scrollbar-thumb { background: var(--label4); border-radius: 3px; }
}

/* ─── DESKTOP LARGE (≥ 1100px) ── */
@media (min-width: 1100px) {
  #app { grid-template-columns: 260px 1fr; }
  #sidebar { width: 260px; }
  .detail-view { left: 260px !important; width: calc(100vw - 260px); }
  .search-overlay, .share-overlay, .quick-log-overlay { left: 260px; width: calc(100vw - 260px); }
  #confetti-canvas { left: 260px; width: calc(100vw - 260px); }
  #piante-list    { grid-template-columns: 1fr 1fr 1fr; }
  #journal-list   { grid-template-columns: 1fr 1fr 1fr; }
  #knowledge-list { grid-template-columns: 1fr 1fr 1fr; }
  .sheet { max-width: 640px; }
}
