:root{--bg: #0b0f0c;--nav-bg: #0c120d;--bg-card: #111811;--bg-inset: #0c120d;--bg-elevated: #18221a;--border: rgba(120, 180, 90, .13);--border-input: rgba(120, 180, 90, .16);--text: #eef3ec;--text-body: #c8d3c2;--text-dim: #8a9a86;--text-faint: #7c8c78;--accent: #9fd07a;--accent-bar: #6fbf3e;--accent-strong: #4d9c28;--accent-soft: rgba(111, 191, 62, .16);--accent-line: rgba(111, 191, 62, .3);--blue: #4f8fd6;--blue-pill: #7fb0e0;--danger: #b06a6a;--danger-dim: #7c5b5b;--warning: #e3b23c;--star-empty: #3a4636;--radius: 13px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Hanken Grotesk,Segoe UI,system-ui,-apple-system,sans-serif;font-size:15px;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app-shell{display:flex;flex-direction:column;min-height:100vh}.topbar{display:flex;align-items:center;gap:28px;min-height:58px;padding:0 28px;border-bottom:1px solid rgba(120,180,90,.14);background:var(--nav-bg);position:sticky;top:0;z-index:10;flex-wrap:wrap}.brand{font-weight:800;font-size:18px;letter-spacing:-.02em;display:flex;align-items:center;gap:8px}.brand .leaf{font-size:22px}.nav{display:flex;gap:4px;flex-wrap:wrap}.nav a{color:var(--text-dim);text-decoration:none;padding:6px 13px;border:1px solid transparent;border-radius:8px;font-weight:500}.nav a:hover{color:var(--text)}.nav a.active{color:var(--accent);background:var(--accent-soft);border-color:var(--accent-line);font-weight:600}.page{padding:34px 28px 80px;max-width:1140px;margin:0 auto;width:100%}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}.page-header h1{margin:0;font-size:27px;font-weight:800;letter-spacing:-.02em}.page-sub{margin:3px 0 0;font-size:14px;color:var(--text-dim)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid-stats{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{padding:16px 17px;display:flex;flex-direction:column}.stat-top{display:flex;align-items:baseline;gap:7px}.stat-value{font-size:30px;font-weight:800;color:var(--text);line-height:1}.stat-value.accent{color:var(--accent)}.stat-unit{color:#c6d2c1;font-size:13px;font-weight:600}.stat-label{color:var(--text-dim);font-size:12.5px;margin-top:7px}.stat-cta{color:var(--accent);font-size:13px;font-weight:600;text-decoration:none;margin-top:7px}.stat-cta:hover{text-decoration:underline}.chart-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.chart-head h3{margin:0;font-size:15px}.range-toggle{display:inline-flex;gap:2px;padding:2px;background:var(--bg);border:1px solid var(--border);border-radius:8px}.range-toggle button{border:none;background:transparent;color:var(--text-dim);font-size:13px;padding:4px 11px;border-radius:6px}.range-toggle button:hover{color:var(--text)}.range-toggle button.on{background:var(--accent-soft);color:var(--accent)}.breakdown-card{display:flex;flex-direction:column}.bd-head{margin-bottom:16px}.bd-head h3{margin:0 0 2px;font-size:15px}.bd-sub{color:var(--text-dim);font-size:12px}.bd-name{text-transform:capitalize}.stacked-bar{display:flex;height:9px;border-radius:5px;overflow:hidden;background:var(--bg);margin-bottom:16px}.stacked-bar>div{height:100%}.bd-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}.bd-legend li{display:flex;align-items:center;gap:9px;font-size:14px}.bd-legend .dot{width:10px;height:10px;border-radius:3px;flex:none}.bd-legend .bd-count{margin-left:auto;font-weight:600}.bd-legend .bd-pct{color:var(--text-dim);font-size:13px;width:38px;text-align:right}.rating-list,.effect-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}.rating-list .rating-top{display:flex;justify-content:space-between;font-size:14px;margin-bottom:6px}.rating-list .rating-val{color:var(--warning);font-weight:600}.track{height:6px;border-radius:999px;background:var(--bg);overflow:hidden}.track .fill{height:100%;border-radius:999px}.fill.gold{background:var(--warning)}.fill.green{background:var(--accent-bar)}.rating-list .track{background:#e3b23c24}.effect-list li{display:flex;align-items:center;gap:10px;font-size:14px}.effect-list .effect-name{width:64px;flex:none;text-transform:capitalize}.effect-list .track{flex:1}.effect-list .effect-count{width:18px;text-align:right;color:var(--text-dim)}button,.btn{font:inherit;border:1px solid var(--border);background:var(--bg-elevated);color:var(--text);padding:8px 16px;border-radius:8px;cursor:pointer}button:hover{border-color:var(--accent)}.btn-primary{background:linear-gradient(#62b837,#4d9c28);border:none;color:#fff;font-weight:700;font-size:14px;border-radius:9px;padding:11px 17px;box-shadow:0 1px #ffffff26 inset,0 6px 16px #46962840}.btn-primary:hover{background:linear-gradient(#6cc23f,#56ab2e);border:none}.btn-danger{color:var(--danger)}.btn-danger:hover{border-color:var(--danger)}.btn-sm{padding:4px 10px;font-size:13px}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:380px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:12px;margin:12px 0}.banner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:16px auto 0;max-width:1000px;width:calc(100% - 40px);padding:12px 16px;background:var(--accent-soft);border:1px solid var(--accent);border-radius:var(--radius);font-size:14px}.banner-actions{display:flex;gap:8px}input,select,textarea{font:inherit;background:var(--bg);color:var(--text);border:1px solid var(--border-input);border-radius:8px;padding:8px 10px;width:100%}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}textarea{resize:vertical;min-height:60px}label.field{display:flex;flex-direction:column;gap:5px;font-size:13px;color:var(--text-dim);font-weight:500}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px}.form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:end}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{padding:5px 12px;border-radius:999px;font-size:13px;border:1px solid var(--border);background:var(--bg);cursor:pointer;color:var(--text-dim)}.chip.on{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.chip.static{cursor:default}.tag{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;background:var(--accent-soft);color:var(--accent)}.tag.indica{background:#9b6ddb2e;color:#b794e8}.tag.sativa{background:#d9a4412e;color:#e3b65c}.tag.hybrid{background:var(--accent-soft);color:var(--accent)}.tag.stage{background:#5d9edb2e;color:#7db4e8}.list{display:flex;flex-direction:column;gap:10px}.list-item{display:flex;gap:12px;align-items:flex-start}.list-item .body{flex:1;min-width:0}.list-item .title{font-weight:600}.list-item .meta{color:var(--text-dim);font-size:13px;margin-top:2px}.list-item .actions{display:flex;gap:6px;flex-shrink:0}.stars{display:inline-flex;gap:2px;cursor:pointer;-webkit-user-select:none;user-select:none}.stars .star{font-size:20px;color:var(--star-empty)}.stars .star.on{color:var(--warning)}.stars.readonly{cursor:default}.stars.readonly .star{font-size:15px}.photo-strip{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.photo-strip img{width:84px;height:84px;object-fit:cover;border-radius:8px;border:1px solid var(--border);cursor:pointer}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:100;cursor:zoom-out}.lightbox img{max-width:92vw;max-height:92vh;border-radius:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow-y:auto}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;width:100%;max-width:560px;display:flex;flex-direction:column;gap:14px}.modal h2{margin:0;font-size:19px}.empty{text-align:center;color:var(--text-dim);padding:40px 16px}.empty .big{font-size:40px;margin-bottom:8px}.fab{position:fixed;right:24px;bottom:24px;width:56px;height:56px;border-radius:50%;background:var(--accent-strong);border:none;color:#fff;font-size:28px;line-height:1;box-shadow:0 4px 16px #0006;z-index:20}.fab:hover{background:var(--accent)}.chart-card h3{margin:0;font-size:15px;color:var(--text);font-weight:700}.chart-caption{font-size:12px;color:var(--text-dim)}.muted{color:var(--text-dim)}.section-title{font-size:17px;font-weight:600;margin:24px 0 12px}hr.sep{border:none;border-top:1px solid var(--border);margin:16px 0}.card-title{margin:0 0 8px;font-size:16px;font-weight:700}.plant-icon{width:32px;height:32px;flex:none;display:flex;align-items:center;justify-content:center;border-radius:9px;font-size:15px;background:#6fbf3e1f;border:1px solid rgba(111,191,62,.28)}.filter-bar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}.search{position:relative;flex:1 1 200px;min-width:200px}.search input{background:var(--bg-card);border-radius:9px;padding:9px 12px 9px 34px}.search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:13px;pointer-events:none;opacity:.85}.segmented{display:inline-flex;gap:2px;padding:3px;background:var(--bg-inset);border:1px solid var(--border-input);border-radius:8px}.segmented button{border:none;background:transparent;color:var(--text-dim);font-size:13px;font-weight:600;padding:6px 12px;border-radius:6px}.segmented button:hover{color:var(--text);border:none}.segmented button.on{background:#6fbf3e2e;color:var(--accent)}.session-list{display:flex;flex-direction:column;gap:8px}.session-row{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;transition:border-color .15s}.session-row:hover{border-color:var(--accent-line)}.session-head{display:flex;align-items:center;gap:13px;width:100%;padding:12px 15px;background:transparent;border:none;border-radius:12px;text-align:left;cursor:pointer}.session-head:hover{border:none}.session-date{width:52px;flex:none;text-align:right}.session-date .d{font-size:13px;font-weight:700;color:#d4ddcf}.session-date .t{font-size:11px;color:#6f7e6b;margin-top:1px}.method-icon{width:32px;height:32px;flex:none;display:flex;align-items:center;justify-content:center;border-radius:9px;font-size:15px}.method-icon.flower{background:#6fbf3e1f;border:1px solid rgba(111,191,62,.28)}.method-icon.edible{background:#4f8fd61f;border:1px solid rgba(79,143,214,.3)}.session-main{flex:1;min-width:0}.session-name{display:flex;align-items:center;gap:7px;min-width:0}.session-name .name-text{font-size:14.5px;font-weight:700;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-name .stars{flex:none}.session-sub{font-size:12px;color:var(--text-dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.session-caret{flex:none;font-size:11px;color:#6f7e6b;transition:transform .15s}.session-row.open .session-caret{transform:rotate(180deg)}.session-detail{display:flex;flex-direction:column;gap:11px;padding:0 15px 15px 67px}.session-tags{display:flex;flex-wrap:wrap;gap:6px}.tag-pill{font-size:11.5px;font-weight:500;color:var(--accent);background:#6fbf3e1a;border:1px solid rgba(111,191,62,.22);border-radius:20px;padding:3px 10px}.session-note{margin:0;font-size:13.5px;line-height:1.6;color:var(--text-body);text-wrap:pretty}.session-detail .photo-strip{margin-top:0}.session-detail .photo-strip img{width:62px;height:62px;border-radius:10px}.delete-link{align-self:flex-start;background:none;border:none;padding:0;font-size:12.5px;color:var(--danger-dim);cursor:pointer}.delete-link:hover{border:none;color:var(--danger);text-decoration:underline}.chart-row{display:grid;grid-template-columns:1.85fr 1fr;gap:14px;margin-bottom:14px}.grid-3{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}.bar-chart{display:flex;align-items:flex-end;gap:14px;height:130px}.bar-chart.dense{gap:4px}.bar{flex:1;max-width:26px;min-height:4px;border-radius:5px 5px 2px 2px;background:linear-gradient(#7fce4a,#5aad33)}.bar.zero{background:#78b45a1f}.bar-labels{display:flex;gap:14px;margin-top:8px}.bar-labels.dense{gap:4px}.bar-labels>span{flex:1;max-width:26px;text-align:center;font-size:10.5px;color:var(--text-faint);white-space:nowrap}.chart-empty{height:168px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:1px dashed rgba(120,180,90,.2);border-radius:11px;background:#78b45a05;text-align:center}.chart-empty .moon{font-size:26px}.chart-empty .e1{font-size:13.5px;font-weight:600;color:#c6d2c1}.chart-empty .e2{font-size:12px;color:var(--text-faint)}.spotlight{display:flex;flex-direction:column;background:linear-gradient(160deg,#15331a,#102713);border:1px solid rgba(120,200,90,.22);border-radius:13px;padding:18px 20px}.spotlight .eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--accent)}.spotlight .sp-name{font-size:21px;font-weight:800;margin:10px 0 6px}.spotlight .sp-rating{display:flex;align-items:center;gap:7px;color:var(--warning);font-weight:600}.spotlight .sp-quote{margin:auto 0 0;padding-top:16px;font-size:12.5px;line-height:1.5;color:#b9c8b3;text-wrap:pretty}@media (max-width: 760px){.chart-row{grid-template-columns:1fr}}.strain-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:start}@media (max-width: 880px){.strain-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.strain-grid{grid-template-columns:1fr}}.strain-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;overflow:hidden}.sc-body{padding:16px 17px 15px}.sc-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.sc-name{font-size:16px;font-weight:700}.sc-actions{display:flex;gap:10px;flex:none}.sc-actions button{background:none;border:none;padding:0;font-size:12.5px;cursor:pointer}.sc-edit{color:var(--text-dim)}.sc-edit:hover{color:var(--text);border:none}.sc-delete{color:#b06a6a}.sc-delete:hover{color:var(--danger);border:none}.sc-pills{display:flex;flex-wrap:wrap;gap:6px;margin:7px 0 13px}.sc-pill{font-size:11px;font-weight:600;border-radius:20px;padding:2px 10px}.sc-pill.type{color:var(--accent);background:#6fbf3e21;border:1px solid rgba(111,191,62,.25)}.sc-pill.flower{color:var(--accent);background:#6fbf3e1a;border:1px solid rgba(111,191,62,.22)}.sc-pill.edible{color:var(--blue-pill);background:#4f8fd61f;border:1px solid rgba(79,143,214,.28)}.sc-potency{display:flex;gap:9px}.sc-tile{flex:1;background:var(--bg-inset);border:1px solid rgba(120,180,90,.12);border-radius:9px;padding:9px 11px}.sc-tile .t-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim)}.sc-tile .t-value{font-size:17px;font-weight:800;margin-top:3px}.sc-terps{margin-top:13px}.sc-terps .terps-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin-bottom:7px}.terps-chips{display:flex;flex-wrap:wrap;gap:6px}.terp-chip{font-size:11.5px;color:#cdd9c7;background:var(--bg-elevated);border:1px solid rgba(120,180,90,.15);border-radius:7px;padding:3px 8px}.terp-chip b{font-weight:700}.sc-details{margin-top:13px;padding-top:13px;border-top:1px solid var(--border);font-size:12px;line-height:1.6;color:#9aa896;text-wrap:pretty}.sc-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:11px 17px;background:#78b45a0a;border-top:1px solid var(--border)}.sc-sessions{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--text-dim)}.sc-toggle{background:none;border:none;padding:0;font-size:12.5px;font-weight:600;color:var(--accent);cursor:pointer;flex:none}.sc-toggle:hover{border:none;text-decoration:underline}@media (max-width: 600px){.topbar{padding:8px 10px;gap:8px;padding-top:calc(8px + env(safe-area-inset-top))}.brand{font-size:16px}.brand .leaf{font-size:19px}.nav{flex-wrap:nowrap;overflow-x:auto;width:100%;-webkit-overflow-scrolling:touch;scrollbar-width:none}.nav::-webkit-scrollbar{display:none}.nav a{padding:7px 11px;font-size:14px;white-space:nowrap}.page{padding:16px 12px calc(96px + env(safe-area-inset-bottom))}.page-header h1{font-size:21px}.modal-backdrop{padding:12px 8px;align-items:stretch}.modal{padding:16px 14px;max-width:none}.list-item{flex-wrap:wrap}.list-item .actions{width:100%;justify-content:flex-end}.fab{right:16px;bottom:calc(16px + env(safe-area-inset-bottom))}button,.btn,input,select,textarea{font-size:16px}}
