@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.0bjc5tiuqdqro.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.0m6w47a4e5dy9.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.11u06r12fd6v_.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.0wxq9webf.ew4.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.067x_6k0k23tk.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.16ipb6fqu393i.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.0q-301v4kxxnr.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_fe8b9d92-module__LINzvG__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_fe8b9d92-module__LINzvG__variable{--font-inter:"Inter", "Inter Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.0s19wthhh_6~m.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.0dza.stei.9v7.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.03nf~dfjdkf~..woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.0gfhww.tctz1o.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.09q3q1i5159bl.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.1409xf.ylxg8g.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_c302529-module__OsiXdW__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_c302529-module__OsiXdW__variable{--font-jetbrains:"JetBrains Mono", "JetBrains Mono Fallback"}
:root{--color-bg-primary:#0d1117;--color-bg-secondary:#161b22;--color-bg-tertiary:#1c2128;--color-bg-card:#161b22;--color-bg-card-hover:#1c2128;--color-bg-input:#0d1117;--color-text-primary:#e5e5e5;--color-text-secondary:#8b949e;--color-text-muted:#6e7681;--color-text-inverse:#0d1117;--color-accent-green:#4ade80;--color-accent-green-dim:#4ade8026;--color-accent-green-glow:#4ade804d;--color-accent-amber:#d29922;--color-accent-amber-dim:#d2992226;--color-accent-blue:#388bfd;--color-accent-blue-dim:#388bfd26;--color-accent-red:#da3633;--color-accent-red-dim:#da363326;--color-accent-purple:#8b5cf6;--color-accent-purple-dim:#8b5cf626;--color-border:#21262d;--color-border-hover:#30363d;--color-border-focus:var(--color-accent-green);--color-bg-hover:#1c2128;--color-border-emphasis:#30363d;--color-accent-cyan:#22d3ee;--color-accent-cyan-dim:#22d3ee26;--color-surface:#161b22;--color-surface-widget-env:#1a3a2a;--color-surface-widget-plant:#1e2d3a;--color-surface-widget-actions:#2a1e3a;--color-surface-widget-cal:#3a2a1e;--color-surface-widget-alert:#3a1a1a;--color-text-disabled:#484f58;--color-dock-bg:#0d1117eb;--color-dock-border:#21262d;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 32px #0009;--shadow-glow:0 0 20px var(--color-accent-green-glow);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-7:1.75rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--glass-bg:#0d111799;--glass-border:#21262d80;--glass-blur:blur(16px);--header-height:64px;--content-max-width:1200px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;height:100%}body{min-height:100%;font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text-primary);background-color:var(--color-bg-primary);background-image:radial-gradient(at 20%,#4ade8008 0%,#0000 50%),radial-gradient(at 80% 20%,#388bfd05 0%,#0000 50%);line-height:1.6}a{color:var(--color-accent-green);transition:color var(--transition-fast);text-decoration:none}a:hover{color:#4ade80}img{max-width:100%;height:auto;display:block}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background-color:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;width:100%}input:focus,textarea:focus,select:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-accent-green-dim)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}@keyframes offlineBannerSlide{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.app-layout{min-height:100vh;display:flex}.nav-link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);font-weight:500;display:flex}.nav-link:hover{background:var(--color-accent-green-dim);color:var(--color-accent-green)}.nav-link.active{background:var(--color-accent-green-dim);color:var(--color-accent-green);box-shadow:inset 3px 0 0 var(--color-accent-green)}.nav-link-icon{font-size:var(--text-lg);text-align:center;width:24px}.main-content{padding:var(--space-8);flex:1;max-width:100vw}.card{background:var(--color-bg-card);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:all var(--transition-base)}.card:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--text-lg);font-weight:600}.card-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-weight:600;font-size:var(--text-sm);transition:all var(--transition-fast);white-space:nowrap;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--color-accent-green), #16a34a);color:var(--color-text-inverse);box-shadow:0 2px 8px #22c55e4d}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #22c55e80}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{border-color:var(--color-border-hover);background:var(--color-bg-card-hover)}.btn-ghost{color:var(--color-text-secondary);padding:var(--space-2) var(--space-3)}.btn-ghost:hover{color:var(--color-text-primary);background:#ffffff0d}.btn-danger{background:var(--color-accent-red-dim);color:var(--color-accent-red);border:1px solid #ef444433}.btn-danger:hover{background:#ef444440}.btn-icon{padding:var(--space-2);border-radius:var(--radius-sm)}.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--text-base);border-radius:var(--radius-lg)}.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--text-xs)}.badge{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;font-weight:600;display:inline-flex}.badge-green{background:var(--color-accent-green-dim);color:var(--color-accent-green)}.badge-amber{background:var(--color-accent-amber-dim);color:var(--color-accent-amber)}.badge-blue{background:var(--color-accent-blue-dim);color:var(--color-accent-blue)}.badge-red{background:var(--color-accent-red-dim);color:var(--color-accent-red)}.badge-purple{background:var(--color-accent-purple-dim);color:var(--color-accent-purple)}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;display:flex}.page-title{font-size:var(--text-3xl);letter-spacing:-.02em;font-weight:700}.page-subtitle{font-size:var(--text-base);color:var(--color-text-secondary);margin-top:var(--space-1)}.grid{gap:var(--space-6);display:grid}.grid-cols-1{grid-template-columns:1fr}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:600}.form-row{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.form-hint{font-size:var(--text-xs);color:var(--color-text-muted)}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%239aada0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--space-6);opacity:.6;font-size:4rem}.empty-state-title{font-size:var(--text-xl);margin-bottom:var(--space-2);font-weight:600}.empty-state-text{color:var(--color-text-muted);max-width:400px;margin-bottom:var(--space-6)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg, var(--color-bg-tertiary) 25%, var(--color-bg-card-hover) 50%, var(--color-bg-tertiary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}.spinner{border:3px solid var(--color-bg-tertiary);border-top-color:var(--color-accent-green);border-radius:var(--radius-full);width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.toast-container{bottom:var(--space-6);right:var(--space-6);z-index:1000;gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4) var(--space-5);box-shadow:var(--shadow-lg);align-items:center;gap:var(--space-3);min-width:300px;animation:.3s ease-out slideIn;display:flex}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-success{border-left:3px solid var(--color-accent-green)}.toast-error{border-left:3px solid var(--color-accent-red)}.toast-warning{border-left:3px solid var(--color-accent-amber)}.toast-info{border-left:3px solid var(--color-accent-blue)}.stat-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(180px,1fr));display:grid}.stat-card{background:var(--color-bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center}.stat-value{font-size:var(--text-3xl);background:linear-gradient(135deg, var(--color-accent-green), #4ade80);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:700}.stat-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.stage-bar{border-radius:var(--radius-full);height:6px;margin-top:var(--space-3);gap:2px;display:flex;overflow:hidden}.stage-bar-segment{background:var(--color-bg-tertiary);transition:background var(--transition-base);flex:1}.stage-bar-segment.active{background:var(--color-accent-green)}.stage-bar-segment.completed{background:var(--color-accent-green);opacity:.5}.bottom-nav{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:100;height:64px;padding:0 env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-inner{justify-content:space-around;align-items:center;max-width:480px;height:100%;margin:0 auto;display:flex}.bottom-nav-item{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-muted);transition:color var(--transition-fast);font-size:var(--text-xs);flex-direction:column;align-items:center;gap:2px;min-width:56px;text-decoration:none;display:flex}.bottom-nav-item.active{color:var(--color-accent-green)}.bottom-nav-item:hover{color:var(--color-text-primary)}.bottom-nav-icon{font-size:1.25rem;line-height:1}.mobile-nav-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:150;background:#0009;animation:.2s fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-nav-drawer{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:200;padding:var(--space-5) var(--space-5) calc(var(--space-6) + env(safe-area-inset-bottom));max-height:70vh;transition:transform .35s cubic-bezier(.32,.72,0,1);position:fixed;bottom:64px;left:0;right:0;overflow-y:auto;transform:translateY(120%);box-shadow:0 -8px 32px #00000080}.mobile-nav-drawer.open{transform:translateY(0)}.mobile-nav-drawer-header{margin-bottom:var(--space-5);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.mobile-nav-drawer-header h2{font-size:var(--text-lg);color:var(--color-text-primary);font-weight:600}.mobile-nav-drawer-close{border-radius:var(--radius-full);background:var(--color-bg-tertiary);width:36px;height:36px;color:var(--color-text-secondary);border:1px solid var(--color-border);font-size:var(--text-lg);cursor:pointer;transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.mobile-nav-drawer-close:hover{background:var(--color-accent-red-dim);color:var(--color-accent-red);border-color:#ef44444d}.mobile-nav-drawer-grid{gap:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.mobile-nav-drawer-item{align-items:center;gap:var(--space-2);padding:var(--space-4) var(--space-2);border-radius:var(--radius-lg);color:var(--color-text-secondary);background:var(--color-bg-tertiary);border:1px solid var(--color-border);transition:all var(--transition-fast);text-align:center;flex-direction:column;text-decoration:none;display:flex}.mobile-nav-drawer-item:hover{background:var(--color-accent-green-dim);color:var(--color-accent-green);border-color:var(--color-accent-green);transform:translateY(-2px)}.mobile-nav-drawer-item.active{background:var(--color-accent-green-dim);color:var(--color-accent-green);border-color:var(--color-accent-green);box-shadow:0 0 12px var(--color-accent-green-glow)}.mobile-nav-drawer-icon{font-size:1.75rem;line-height:1}.mobile-nav-drawer-label{font-size:var(--text-xs);font-weight:500}@media (min-width:769px) and (max-width:1024px){.grid-cols-3,.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.main-content{padding:var(--space-4);padding-bottom:calc(64px + var(--space-4) + env(safe-area-inset-bottom));max-width:100vw}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.page-header{align-items:flex-start;gap:var(--space-4);flex-direction:column}.toast-container{right:var(--space-3);left:var(--space-3);bottom:calc(64px + var(--space-3))}.btn,.btn-primary,.btn-secondary,.btn-ghost,.btn-danger,.btn-icon,.btn-lg,.btn-sm,.bottom-nav-item,.nav-link,.mobile-nav-drawer-item{min-width:44px;min-height:44px}input,textarea,select{min-height:44px;font-size:max(var(--text-base), 16px)}.card{padding:var(--space-5)}.btn-primary{padding:var(--space-4) var(--space-6);font-size:var(--text-base)}.main-content{-webkit-overflow-scrolling:touch}.btn:active,.btn-primary:active,.card:active{transition:transform .1s;transform:scale(.97)}}@media (max-width:768px) and (orientation:landscape){.bottom-nav{height:48px}.mobile-nav-drawer{bottom:48px}.main-content{padding-bottom:calc(48px + var(--space-4) + env(safe-area-inset-bottom))}.toast-container{bottom:calc(48px + var(--space-3))}}@keyframes installSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.install-prompt{z-index:90;background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-top:1px solid var(--glass-border);padding:var(--space-4) var(--space-5);padding-bottom:calc(64px + var(--space-4) + env(safe-area-inset-bottom));justify-content:space-between;align-items:center;gap:var(--space-4);animation:.4s cubic-bezier(.32,.72,0,1) installSlideUp;display:flex;position:fixed;bottom:0;left:0;right:0}.install-prompt-icon{flex-shrink:0;font-size:2rem}.install-prompt-text{flex:1;min-width:0}.install-prompt-title{font-weight:600;font-size:var(--text-sm);color:var(--color-text-primary)}.install-prompt-subtitle{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.install-prompt-actions{gap:var(--space-2);flex-shrink:0;display:flex}.install-prompt-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:600}.install-prompt-btn-primary{background:var(--color-accent-green);color:var(--color-text-inverse)}.install-prompt-btn-secondary{color:var(--color-text-secondary);border:1px solid var(--color-border);background:0 0}@keyframes syncPulse{0%,to{box-shadow:0 0 0 0 var(--color-accent-green-glow)}50%{box-shadow:0 0 0 8px #0000}}@keyframes syncFadeOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-hover)}.photo-grid>div:hover .photo-overlay,.photo-grid>div:hover .photo-delete-btn{opacity:1!important}.timeline-day-header:hover{opacity:.85}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.font-mono{font-family:var(--font-mono)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.w-full{width:100%}.wiki-content h1{font-size:var(--text-2xl);color:var(--color-accent-green);margin:var(--space-6) 0 var(--space-3);border-bottom:1px solid var(--color-border);padding-bottom:var(--space-2);font-weight:700}.wiki-content h2{font-size:var(--text-xl);color:var(--color-text-primary);margin:var(--space-5) 0 var(--space-3);font-weight:600}.wiki-content h3{font-size:var(--text-lg);color:var(--color-text-primary);margin:var(--space-4) 0 var(--space-2);font-weight:600}.wiki-content p{margin:var(--space-3) 0;line-height:1.7}.wiki-content ul{margin:var(--space-2) 0;padding-left:var(--space-6)}.wiki-content li{margin:var(--space-1) 0;line-height:1.6}.wiki-content strong{color:var(--color-text-primary);font-weight:600}.wiki-content code.inline-code{background:var(--color-bg-tertiary);border-radius:var(--radius-sm);font-family:var(--font-mono);color:var(--color-accent-green);padding:2px 6px;font-size:.9em}.wiki-content pre,.wiki-content pre code.code-block{background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-text-primary);overflow-x:auto}.wiki-content table.wiki-table,.wiki-content table{border-collapse:collapse;width:100%;margin:var(--space-4) 0}.wiki-content td{border:1px solid var(--color-border);padding:var(--space-2) var(--space-3);text-align:left}.wiki-content hr.wiki-hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-6) 0}.wiki-content a{color:var(--color-accent-green);text-decoration:underline}.wiki-content em{color:var(--color-text-secondary);font-style:italic}.usage-period-tabs{border-radius:var(--radius-sm);background:#ffffff0a;gap:2px;padding:2px;display:flex}.usage-tab{font-size:var(--text-xs);color:var(--color-text-muted);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 12px;font-weight:500}.usage-tab:hover{color:var(--color-text-secondary);background:#ffffff0a}.usage-tab.active{color:var(--color-text-primary);background:#22c55e26;box-shadow:0 1px 3px #0003}.usage-sparkline{align-items:flex-end;gap:4px;width:100%;height:48px;display:flex}.usage-sparkline-bar-wrapper{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.usage-sparkline-bar{border-radius:2px 2px 0 0;width:100%;min-height:3px;transition:height .4s}.usage-sparkline-label{color:var(--color-text-muted);font-size:9px;font-family:var(--font-mono);margin-top:2px}.not-found{text-align:center;min-height:70vh;padding:var(--space-8);flex-direction:column;justify-content:center;align-items:center;display:flex}.not-found__icon{margin-bottom:var(--space-4);font-size:5rem}.not-found__title{font-size:var(--text-4xl);margin:0;margin-bottom:var(--space-2);background:linear-gradient(135deg, var(--color-accent-green), #22c55e);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-weight:800}.not-found__subtitle{font-size:var(--text-xl);color:var(--color-text-secondary);margin:0;margin-bottom:var(--space-4);font-weight:600}.not-found__text{color:var(--color-text-muted);max-width:400px;margin-bottom:var(--space-6);line-height:1.6}.not-found__link{text-decoration:none}.offline-page{min-height:60vh;padding:var(--space-8);text-align:center;justify-content:center;align-items:center;gap:var(--space-6);flex-direction:column;display:flex}.offline-page-icon{opacity:.6;font-size:4rem}.offline-page h1{font-size:var(--text-2xl);color:var(--color-text-primary);font-weight:700}.offline-page p{color:var(--color-text-secondary);max-width:360px;line-height:1.6}.offline-page-actions{gap:var(--space-4);flex-wrap:wrap;justify-content:center;display:flex}.offline-nav-indicator{font-size:var(--text-xs);color:var(--color-accent-amber);white-space:nowrap;font-weight:600;position:absolute;top:-20px;left:50%;transform:translate(-50%)}.widget-grid{gap:var(--space-4);padding:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.widget-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);transition:border-color var(--transition-fast);cursor:pointer}.widget-card:hover{border-color:var(--color-border-emphasis)}.widget-card__header{align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);font-size:var(--text-lg);font-weight:600;display:flex}.widget-card__body{color:var(--color-text-secondary)}.widget--env{border-left:3px solid var(--color-accent-green)}.widget--plant{border-left:3px solid var(--color-accent-blue)}.widget--actions{border-left:3px solid var(--color-accent-purple)}.widget--calendar{border-left:3px solid var(--color-accent-amber)}.widget--alert{border-left:3px solid var(--color-accent-red)}.dock{gap:var(--space-1);padding:var(--space-2) var(--space-4);background:var(--color-dock-bg);border:1px solid var(--color-dock-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;border-bottom:none;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.dock__item{align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);transition:all var(--transition-fast);font-size:var(--text-xs);flex-direction:column;min-width:56px;text-decoration:none;display:flex}.dock__item:hover,.dock__item--active{color:var(--color-accent-green);background:var(--color-bg-hover)}.dock__item-icon{font-size:var(--text-xl);line-height:1}.bottom-tabs{padding:var(--space-2) 0;background:var(--color-dock-bg);border-top:1px solid var(--color-dock-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:100;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.bottom-tabs__item{padding:var(--space-1) var(--space-3);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--text-xs);transition:color var(--transition-fast);flex-direction:column;align-items:center;gap:2px;text-decoration:none;display:flex}.bottom-tabs__item--active{color:var(--color-accent-green)}.bottom-tabs__item-icon{font-size:var(--text-lg);line-height:1}@media (min-width:768px){.bottom-tabs{display:none}.dock{display:flex}}@media (max-width:767px){.dock{display:none}.bottom-tabs{display:flex}}.app-main{min-height:100dvh;padding-bottom:72px}@media (min-width:768px){.app-main{padding-bottom:80px}}.list-menu{gap:var(--space-1);padding:var(--space-4) 0;flex-direction:column;display:flex}.list-menu__item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--color-text-primary);transition:background-color var(--transition-fast);text-decoration:none;display:flex}.list-menu__item:hover{background:var(--color-bg-hover)}.list-menu__icon{font-size:var(--text-xl);text-align:center;flex-shrink:0;width:40px}.list-menu__label{font-size:var(--text-base);flex:1}.list-menu__arrow{color:var(--color-text-muted);font-size:var(--text-lg)}.widget-env__grid{gap:var(--space-3);margin:var(--space-3) 0;grid-template-columns:1fr 1fr 1fr;display:grid}.widget-env__metric{text-align:center}.widget-env__value{font-size:var(--text-2xl);color:var(--color-accent-green);font-weight:700;display:block}.widget-env__label{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1);display:block}.widget-env__status{font-size:var(--text-sm)}.widget-env__status--good{color:var(--color-accent-green)}.widget-env__status--warning{color:var(--color-accent-amber)}.widget-env__status--critical{color:var(--color-accent-red)}.widget-env__target{margin-top:var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted)}.page-header{padding:var(--space-4) var(--space-4) 0;margin-bottom:var(--space-2);justify-content:space-between;align-items:flex-start;display:flex}.page-header__title{font-size:var(--text-2xl);color:var(--color-text-primary);font-weight:700}.page-header__subtitle{font-size:var(--text-sm);color:var(--color-text-secondary);margin-top:var(--space-1)}.page-header__action{align-items:center;gap:var(--space-2);margin-left:auto;display:flex}@media (min-width:1024px){.page-header{max-width:1100px;margin:0 auto var(--space-2);padding:var(--space-6) var(--space-6) 0}}@media (max-width:639px){.widget-grid{gap:var(--space-3);padding:var(--space-3);grid-template-columns:1fr}}@media (min-width:640px) and (max-width:1023px){.widget-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.widget-grid{max-width:1100px;padding:var(--space-6);grid-template-columns:repeat(3,1fr);margin:0 auto}}.ai-fab{background:var(--color-accent-purple);color:#fff;cursor:pointer;z-index:110;width:52px;height:52px;transition:transform var(--transition-fast);border:none;border-radius:50%;font-size:22px;animation:3s ease-in-out infinite ai-fab-pulse;position:fixed;bottom:90px;right:20px;box-shadow:0 4px 12px #8b5cf666}.ai-fab:hover{transform:scale(1.1)}.export-manager{gap:var(--space-6);flex-direction:column;display:flex}.export-manager__section{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6)}.export-manager__section-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.export-manager__section-title{font-size:var(--text-lg);color:var(--color-text-primary);font-weight:600}.export-manager__success{background:var(--color-accent-green-dim);border-radius:var(--radius-md);padding:var(--space-4);margin-bottom:var(--space-4);border:1px solid #4ade8033}.export-manager__success-link{gap:var(--space-2);margin-top:var(--space-2);display:flex}.export-manager__success-input{font-size:var(--text-sm);font-family:var(--font-mono);padding:var(--space-2) var(--space-3);background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-accent-green);flex:1}.export-manager__form{gap:var(--space-4);padding:var(--space-4);background:var(--color-bg-tertiary);border-radius:var(--radius-md);margin-top:var(--space-4);flex-direction:column;display:flex}.export-manager__checkboxes{gap:var(--space-6);display:flex}.export-manager__checkbox-label{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;display:flex}.export-manager__checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-accent-green);cursor:pointer}.export-manager__form-actions{justify-content:flex-end;gap:var(--space-3);display:flex}.export-manager__list{gap:var(--space-3);flex-direction:column;display:flex}.export-manager__item{padding:var(--space-4);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:var(--space-4);display:flex}.export-manager__item-info{flex:1;min-width:0}.export-manager__item-title{font-weight:600;font-size:var(--text-base);color:var(--color-text-primary);margin-bottom:var(--space-1)}.export-manager__item-meta{align-items:center;gap:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);flex-wrap:wrap;display:flex}.export-manager__item-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.delete-modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10000;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.delete-modal-card{background:var(--color-bg-card);border:1px solid var(--glass-border);border-left:3px solid var(--color-accent-red);border-radius:var(--radius-lg);padding:var(--space-6);width:90%;max-width:450px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.delete-modal-title{font-size:var(--text-xl);color:var(--color-text-primary);margin-bottom:var(--space-3);font-weight:600}.delete-modal-message{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-6);line-height:1.6}.delete-modal-actions{justify-content:flex-end;gap:var(--space-3);display:flex}.delete-modal-confirm-btn{align-items:center;gap:var(--space-2);display:inline-flex}.delete-modal-spinner{border:2px solid #0000;border-top-color:currentColor;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.6s linear infinite spin;display:inline-block}@media (max-width:768px){.export-manager__item{flex-direction:column;align-items:flex-start}.export-manager__item-actions{flex-wrap:wrap;justify-content:flex-start;width:100%}.export-manager__checkboxes{gap:var(--space-3);flex-direction:column}}.export-manager__expiration-options{gap:var(--space-4);flex-wrap:wrap;display:flex}.export-manager__radio-label{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;display:flex}.export-manager__radio-label input[type=radio]{width:16px;height:16px;accent-color:var(--color-accent-green);cursor:pointer}@keyframes ai-fab-pulse{0%,to{box-shadow:0 4px 12px #8b5cf666}50%{box-shadow:0 4px 20px #8b5cf6b3}}.share-dialog__overlay{z-index:9999;background:#0009;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.share-dialog__card{background:var(--color-bg-card);border-radius:var(--radius-lg);border:1px solid var(--glass-border);width:90vw;max-width:520px;max-height:90vh;padding:var(--space-6);box-shadow:var(--shadow-lg);animation:.25s slideUp;overflow-y:auto}.share-dialog__header{margin-bottom:var(--space-5);justify-content:space-between;align-items:center;display:flex}.share-dialog__close{cursor:pointer;color:var(--color-text-secondary);padding:var(--space-1);transition:color var(--transition-fast);background:0 0;border:none;font-size:1.25rem;line-height:1}.share-dialog__close:hover{color:var(--color-accent-green)}.share-dialog__error{border-left:3px solid var(--color-accent-red);padding:var(--space-4);margin-bottom:var(--space-4)}.share-dialog__error p{margin:0 0 var(--space-3) 0;color:var(--color-accent-red)}.share-dialog__success{padding:var(--space-4) 0}.share-dialog__success p{margin:0 0 var(--space-3) 0;color:var(--color-accent-green);font-weight:600;font-size:var(--text-base)}.share-dialog__success-link{gap:var(--space-2);display:flex}.share-dialog__success-input{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-tertiary);color:var(--color-text-primary);font-size:var(--text-sm);font-family:var(--font-mono);flex:1}.share-dialog__form{gap:var(--space-4);flex-direction:column;display:flex}.share-dialog__expiration-options{gap:var(--space-4);flex-wrap:wrap;display:flex}.share-dialog__radio-label{align-items:center;gap:var(--space-1);cursor:pointer;color:var(--color-text-secondary);font-size:var(--text-sm);transition:color var(--transition-fast);display:flex}.share-dialog__radio-label:hover{color:var(--color-accent-green)}.share-dialog__radio-label input[type=radio]{accent-color:var(--color-accent-green)}.share-dialog__checkboxes{gap:var(--space-2);flex-direction:column;display:flex}.share-dialog__checkbox-label{align-items:center;gap:var(--space-2);cursor:pointer;color:var(--color-text-secondary);font-size:var(--text-sm);transition:color var(--transition-fast);display:flex}.share-dialog__checkbox-label:hover{color:var(--color-accent-green)}.share-dialog__checkbox-label input[type=checkbox]{accent-color:var(--color-accent-green);width:16px;height:16px}.share-dialog__form-actions{justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-2);display:flex}@media (max-width:480px){.share-dialog__card{padding:var(--space-4);width:95vw}.share-dialog__expiration-options{gap:var(--space-2)}}.share-page{min-height:100dvh;padding:var(--space-8) var(--space-4);background:var(--color-bg-primary);background-image:radial-gradient(at 20%,#4ade8008 0%,#0000 50%),radial-gradient(at 80% 20%,#388bfd05 0%,#0000 50%);flex-direction:column;justify-content:center;align-items:center;display:flex}.share-card{background:var(--color-bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-8);width:100%;max-width:540px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.share-card__hero{text-align:center;margin-bottom:var(--space-6);padding:var(--space-8) var(--space-4);border-radius:var(--radius-lg);position:relative;overflow:hidden}.share-card__hero-bg{border-radius:var(--radius-lg);background:radial-gradient(at 30%,#4ade801f 0%,#0000 60%),radial-gradient(at 70% 30%,#388bfd14 0%,#0000 50%),linear-gradient(135deg,#4ade800d,#388bfd08);position:absolute;inset:0}.share-card__hero>:not(.share-card__hero-bg){z-index:1;position:relative}.share-card__icon{margin-bottom:var(--space-3);font-size:3rem;display:block}.share-card__title{font-size:var(--text-2xl);color:var(--color-text-primary);margin-bottom:var(--space-1);font-weight:700}.share-card__grow-name{font-size:var(--text-base);color:var(--color-accent-green);font-weight:500}.share-card__meta{gap:var(--space-3);margin-bottom:var(--space-6);padding:var(--space-4);background:var(--color-bg-tertiary);border-radius:var(--radius-md);flex-direction:column;display:flex}.share-card__meta-row{font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.share-card__meta-label{color:var(--color-text-muted)}.share-card__meta-value{color:var(--color-text-primary);font-weight:500}.share-card__expires{font-size:var(--text-sm);justify-content:space-between;align-items:center;display:flex}.share-card__active{color:var(--color-accent-green);font-weight:600}.share-card__expired{color:var(--color-accent-red);font-weight:600}.share-card__never-expires{color:var(--color-accent-green);font-weight:600}.share-card__download-section{margin-bottom:var(--space-2)}.share-card__download-btn{justify-content:center;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-4) var(--space-6);background:linear-gradient(135deg, var(--color-accent-green), #16a34a);color:var(--color-text-inverse);border-radius:var(--radius-md);font-size:var(--text-base);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:700;display:flex;box-shadow:0 2px 8px #22c55e4d}.share-card__download-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #22c55e80}.share-card__download-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.share-card__processing{text-align:center;padding:var(--space-6)}.share-card__processing-text{font-size:var(--text-base);color:var(--color-accent-amber);margin-top:var(--space-3);font-weight:500}.share-card__processing-sub{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-2)}.share-card__error{text-align:center;padding:var(--space-6)}.share-card__error-icon{margin-bottom:var(--space-3);font-size:3rem;display:block}.share-card__error-title{font-size:var(--text-xl);color:var(--color-accent-red);margin-bottom:var(--space-2);font-weight:600}.share-card__error-text{font-size:var(--text-sm);color:var(--color-text-muted)}.share-card__description{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-4);line-height:1.6}.share-card__header{align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);flex-direction:column;display:flex}.share-card__includes{gap:var(--space-2);margin-bottom:var(--space-4);flex-wrap:wrap;display:flex}.share-page__footer{margin-top:var(--space-6);text-align:center;font-size:var(--text-xs);color:var(--color-text-muted)}.share-page__footer a{color:var(--color-accent-green);text-decoration:none}.share-page__footer a:hover{text-decoration:underline}@media (max-width:480px){.share-card{padding:var(--space-6)}.share-card__hero{padding:var(--space-6) var(--space-3)}}.share-page__container{gap:var(--space-8);flex-direction:column;width:100%;max-width:960px;display:flex}.share-page__header{text-align:center;padding:var(--space-8) var(--space-4);background:var(--color-bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);position:relative;overflow:hidden}.share-page__header:before{content:"";pointer-events:none;background:radial-gradient(at 30%,#4ade8014 0%,#0000 60%),radial-gradient(at 70% 30%,#388bfd0d 0%,#0000 50%);position:absolute;inset:0}.share-page__header>*{position:relative}.share-page__header-icon{margin-bottom:var(--space-3);font-size:3rem;display:block}.share-page__header-title{font-size:var(--text-3xl);color:var(--color-text-primary);margin-bottom:var(--space-2);letter-spacing:-.02em;font-weight:700}.share-page__header-strain{font-size:var(--text-lg);color:var(--color-accent-green);margin-bottom:var(--space-4);font-weight:500}.share-page__header-meta{justify-content:center;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.share-page__header-env,.share-page__header-date{font-size:var(--text-sm);color:var(--color-text-secondary)}.share-page__header-desc{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-4);line-height:1.6}.share-page__metrics-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));display:grid}.share-page__metric-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.share-page__metric-icon{margin-bottom:var(--space-2);font-size:1.5rem}.share-page__metric-value{font-size:var(--text-2xl);color:var(--color-accent-green);margin-bottom:var(--space-1);font-weight:700}.share-page__metric-label{font-size:var(--text-sm);color:var(--color-text-muted)}.share-page__metric-sub{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-1)}.share-page__section{gap:var(--space-4);flex-direction:column;display:flex}.share-page__section-title{font-size:var(--text-xl);color:var(--color-text-primary);font-weight:600}.share-page__empty{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-6);text-align:center;background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.share-page__photo-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.share-page__photo-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);overflow:hidden}.share-page__photo-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.share-page__photo-img{aspect-ratio:1;object-fit:cover;background:var(--color-bg-tertiary);width:100%;display:block}.share-page__photo-caption{padding:var(--space-2) var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.share-page__photo-date{padding:0 var(--space-3) var(--space-2);font-size:var(--text-xs);color:var(--color-text-muted)}.share-page__log-list{gap:var(--space-3);flex-direction:column;display:flex}.share-page__log-entry{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);box-shadow:var(--shadow-lg)}.share-page__log-date{font-size:var(--text-xs);color:var(--color-text-muted);font-family:var(--font-mono);margin-bottom:var(--space-2)}.share-page__log-metrics{gap:var(--space-2);margin-bottom:var(--space-6);justify-content:center;display:flex}.share-card__section-title{font-size:var(--text-lg);color:var(--color-text-primary);margin-bottom:var(--space-4);margin-top:var(--space-6);font-weight:600}.share-page__lightbox{z-index:10000;cursor:pointer;background:#000000e6;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.share-page__lightbox-inner{cursor:default;max-width:90vw;max-height:90vh;position:relative}.share-page__lightbox-close{color:#fff;font-size:var(--text-xl);cursor:pointer;padding:var(--space-2);transition:color var(--transition-fast);background:0 0;border:none;position:absolute;top:-40px;right:0}.share-page__lightbox-close:hover{color:var(--color-accent-green)}.share-page__lightbox-img{object-fit:contain;border-radius:var(--radius-md);max-width:90vw;max-height:85vh}@media (max-width:768px){.share-page__metrics-grid,.share-page__photo-grid{grid-template-columns:repeat(2,1fr)}.share-page__header{padding:var(--space-6) var(--space-3)}.share-page__header-title{font-size:var(--text-2xl)}}@media (max-width:480px){.share-page__photo-grid{grid-template-columns:1fr}}.share-page__state-card{text-align:center;width:100%;max-width:480px;padding:var(--space-10) var(--space-6);background:var(--color-bg-card);border:1px solid var(--glass-border);border-radius:var(--radius-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur)}.share-page__state-icon{margin-bottom:var(--space-4);font-size:3rem;display:block}.share-page__state-title{font-size:var(--text-xl);color:var(--color-accent-red);margin-bottom:var(--space-2);font-weight:600}.share-page__state-text{font-size:var(--text-sm);color:var(--color-text-secondary)}.share-page__state-subtext{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:var(--space-2)}.share-page__header-date-row{gap:var(--space-6);margin-top:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.share-page__header-actions{gap:var(--space-2);margin-top:var(--space-4);flex-shrink:0;justify-content:center;display:flex}.share-page--centered{justify-content:center;align-items:center}.share-page--padded{padding:var(--space-4)}.share-page__header-row{justify-content:space-between;align-items:flex-start;gap:var(--space-4);flex-wrap:wrap;display:flex}.share-page__header-subtitle{font-size:var(--text-sm);color:var(--color-accent-green);font-weight:500}.share-page__badge-row{gap:var(--space-2);margin-top:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}.share-page__date-row{gap:var(--space-6);margin-top:var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary);flex-wrap:wrap;justify-content:center;display:flex}.share-page__main{gap:var(--space-10);width:100%;max-width:960px;padding:var(--space-8) var(--space-4);flex-direction:column;display:flex}.share-page__footer-link{color:var(--color-accent-green);text-decoration:none}.share-page__footer-link:hover{text-decoration:underline}.share-page__photo-img--loaded{border-radius:var(--radius-md);opacity:1;height:100%;transition:opacity .3s}.share-page__photo-img--hidden{border-radius:var(--radius-md);opacity:0;height:100%;transition:opacity .3s}.share-page__metric-value--good{color:var(--color-accent-green)}.share-page__metric-value--warning{color:var(--color-accent-amber)}.share-page__metric-value--danger{color:var(--color-accent-red)}.share-page__metric-value--neutral{color:var(--color-text-primary)}.share-page__log-metric--good{color:var(--color-accent-green)}.share-page__log-metric--warning{color:var(--color-accent-amber)}.share-page__log-metric--danger{color:var(--color-accent-red)}.share-page__log-metric--neutral{color:var(--color-text-primary)}.share-page__body{gap:var(--space-10);padding:var(--space-8) var(--space-4);flex-direction:column;display:flex}.share-page__photo-img-wrapper{aspect-ratio:1;background:var(--color-bg-tertiary);position:relative;overflow:hidden}.share-page__photo-placeholder{justify-content:center;align-items:center;gap:var(--space-1);flex-direction:column;display:flex;position:absolute;inset:0}.share-page__photo-placeholder-icon{font-size:2rem}.share-page__photo-placeholder-text{font-size:var(--text-xs);color:var(--color-text-muted)}.share-page__photo-info{padding:var(--space-2) var(--space-3)}.share-page__log-metrics{gap:var(--space-3);margin-bottom:var(--space-2);flex-wrap:wrap;display:flex}.share-page__log-metric{font-size:var(--text-xs);font-family:var(--font-mono)}.share-page__log-notes{color:var(--color-text-secondary);font-size:var(--text-sm);margin:0;line-height:1.5}.share-page__plants-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.share-page__plant-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5)}.share-page__plant-header{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.share-page__plant-strain{color:var(--color-text-primary);font-weight:600;font-size:var(--text-base)}.share-page__plant-notes{color:var(--color-text-secondary);font-size:var(--text-sm);margin:0;font-style:italic}.share-page__footer-text{margin:0}.share-page__footer-actions{margin-top:var(--space-4);gap:var(--space-3);flex-wrap:wrap;justify-content:center;display:flex}@media (max-width:480px){.share-page__body,.share-page__main{padding:var(--space-6) var(--space-3)}.share-page__state-card{padding:var(--space-8) var(--space-4)}}.share-dialog__overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;padding:var(--space-4);background:#000000b3;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.share-dialog{background:var(--color-bg-card);border:1px solid var(--glass-border,var(--color-border));border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;box-shadow:var(--shadow-lg);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);animation:.25s slideUp;overflow-y:auto}.share-dialog__header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.share-dialog__title{font-size:var(--text-lg);color:var(--color-text-primary);margin:0;font-weight:600}.share-dialog__close{color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);transition:color var(--transition-fast);border-radius:var(--radius-sm);background:0 0;border:none;font-size:1.5rem;line-height:1}.share-dialog__close:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.share-dialog__form{padding:var(--space-5);gap:var(--space-4);flex-direction:column;display:flex}.share-dialog__field{gap:var(--space-1);flex-direction:column;display:flex}.share-dialog__label{font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:500}.share-dialog__input,.share-dialog__select{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);padding:var(--space-2) var(--space-3);font-size:var(--text-sm);transition:border-color var(--transition-fast);outline:none;font-family:inherit}.share-dialog__input:focus,.share-dialog__select:focus{border-color:var(--color-accent-green)}.share-dialog__select{cursor:pointer;appearance:auto}.share-dialog__checkbox{align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-primary);display:flex}.share-dialog__checkbox input[type=checkbox]{accent-color:var(--color-accent-green);cursor:pointer;width:16px;height:16px}.share-dialog__actions{gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--color-border);margin-top:var(--space-2);justify-content:flex-end;display:flex}.share-dialog__actions button{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);font-weight:500}.share-dialog__actions button[type=button]{border:1px solid var(--color-border);color:var(--color-text-secondary);background:0 0}.share-dialog__actions button[type=button]:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.share-dialog__actions button[type=submit]{background:var(--color-accent-green);color:var(--color-text-inverse);border:none}.share-dialog__actions button[type=submit]:hover{opacity:.9}.share-dialog__result{padding:var(--space-5)}.share-dialog__result-url{gap:var(--space-2);align-items:center;display:flex}.share-dialog__copy-btn{padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border);white-space:nowrap;font-weight:500}.share-dialog__copy-btn:hover{border-color:var(--color-accent-green)}.export-manager__header{justify-content:flex-end;display:flex}.export-manager__error{align-items:center;gap:var(--space-3);padding:var(--space-6);text-align:center;color:var(--color-accent-red);font-size:var(--text-sm);flex-direction:column;display:flex}.export-manager__error button{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}.export-manager__error button:hover{background:var(--color-bg-hover);border-color:var(--color-accent-green)}.export-manager__empty{text-align:center;padding:var(--space-8);color:var(--color-text-muted);font-size:var(--text-sm);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.export-manager__card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);transition:border-color var(--transition-fast)}.export-manager__card:hover{border-color:var(--color-border-hover)}.export-manager__card-title{font-size:var(--text-base);color:var(--color-text-primary);font-weight:600}.export-manager__card-meta{gap:var(--space-4);font-size:var(--text-xs);color:var(--color-text-muted);margin-bottom:var(--space-3);flex-wrap:wrap;display:flex}.export-manager__card-url{gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.export-manager__card-actions{align-items:center;gap:var(--space-3);display:flex}@media (max-width:480px){.share-dialog{border-radius:var(--radius-md);max-width:100%}.share-dialog__card-url,.export-manager__card-url{flex-direction:column}}.ai-drawer-backdrop{z-index:100;opacity:0;pointer-events:none;background:#00000080;transition:opacity .2s;position:fixed;inset:0}.ai-drawer-backdrop--visible{opacity:1;pointer-events:auto}.ai-drawer{background:var(--color-bg-primary);border-left:1px solid var(--color-border);z-index:101;flex-direction:column;width:420px;max-width:100vw;height:100dvh;transition:transform .2s;display:flex;position:fixed;top:0;right:0;transform:translate(100%);box-shadow:-4px 0 24px #0006}.ai-drawer--open{transform:translate(0)}.ai-drawer__header{padding:var(--space-4);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.ai-drawer__header-left{align-items:center;gap:var(--space-3);display:flex}.ai-drawer__icon{font-size:var(--text-xl)}.ai-drawer__title{font-size:var(--text-lg);color:var(--color-text-primary);margin:0;font-weight:600}.ai-drawer__header-actions{align-items:center;gap:var(--space-2);display:flex}.ai-drawer__close{color:var(--color-text-secondary);font-size:var(--text-lg);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-sm);transition:color var(--transition-fast), background var(--transition-fast);background:0 0;border:none;line-height:1}.ai-drawer__close:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.ai-drawer__error-banner{padding:var(--space-2) var(--space-4);background:var(--color-accent-red);color:var(--color-accent-red);font-size:var(--text-sm);background:#da363326;border-bottom:1px solid #da36334d;flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.ai-drawer__error-banner button{color:var(--color-accent-red);cursor:pointer;font-size:var(--text-base);background:0 0;border:none}.ai-drawer__messages{padding:var(--space-4);gap:var(--space-3);scrollbar-width:thin;scrollbar-color:var(--color-bg-tertiary) transparent;flex-direction:column;flex:1;display:flex;overflow-y:auto}.ai-drawer__messages::-webkit-scrollbar{width:4px}.ai-drawer__messages::-webkit-scrollbar-track{background:0 0}.ai-drawer__messages::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-full)}.ai-drawer .grow-selector{font-size:var(--text-xs)}.ai-drawer .grow-selector__trigger{padding:var(--space-1) var(--space-3)}.ai-drawer .cm-message{font-size:var(--text-sm)}.ai-drawer .sq-list{padding:var(--space-2) var(--space-4);gap:var(--space-2)}.ai-drawer .sq-chip{font-size:var(--text-xs);padding:var(--space-1) var(--space-3)}.ai-drawer .chat-input{border-top:1px solid var(--color-border);padding:var(--space-3)}@media (max-width:480px){.ai-drawer{width:100vw}}.skip-link{top:-100%;left:var(--space-4);z-index:9999;background:var(--color-accent-green);color:#000;padding:var(--space-3) var(--space-6);border-radius:var(--radius-md);font-weight:600;text-decoration:none;transition:top .2s;position:absolute}.skip-link:focus{top:var(--space-4)}:focus-visible{outline-offset:2px;border-radius:var(--radius-sm);outline:2px solid var(--color-accent-green)!important}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}
html{transition:background-color var(--transition-base), color var(--transition-base)}body,.card,.stat-card,.toast,input,textarea,select,.btn-secondary,.badge,.nav-link{transition:background-color var(--transition-base), color var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base)}[data-theme=light]{--color-bg-primary:#f6f8fa;--color-bg-secondary:#fff;--color-bg-tertiary:#eaeef2;--color-bg-card:#fff;--color-bg-card-hover:#f3f4f6;--color-bg-input:#fff;--color-text-primary:#1f2328;--color-text-secondary:#656d76;--color-text-muted:#8b949e;--color-text-inverse:#fff;--color-accent-green:#16a34a;--color-accent-green-dim:#16a34a1a;--color-accent-green-glow:#16a34a33;--color-accent-amber:#9a6700;--color-accent-amber-dim:#9a67001a;--color-accent-blue:#1f6feb;--color-accent-blue-dim:#1f6feb1a;--color-accent-red:#cf222e;--color-accent-red-dim:#cf222e1a;--color-accent-purple:#8250df;--color-accent-purple-dim:#8250df1a;--color-border:#d0d7de;--color-border-hover:#afb8c1;--color-border-focus:var(--color-accent-green);--shadow-sm:0 1px 2px #1f23280f;--shadow-md:0 4px 12px #1f232814;--shadow-lg:0 8px 32px #1f23281a;--shadow-glow:0 0 20px var(--color-accent-green-glow);--glass-bg:#ffffffb3;--glass-border:#1f23280f}[data-theme=light] body{background-image:radial-gradient(at 20%,#16a34a08 0%,#0000 50%),radial-gradient(at 80% 20%,#1f6feb05 0%,#0000 50%)}[data-theme=light] .stat-value{background:linear-gradient(135deg, var(--color-accent-green), #16a34a);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}[data-theme=light] .btn-primary{background:linear-gradient(135deg, var(--color-accent-green), #15803d);box-shadow:0 2px 8px #16a34a33}[data-theme=light] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%234a5e52' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}[data-theme=light] ::-webkit-scrollbar-thumb{background:#00000026}[data-theme=light] ::-webkit-scrollbar-thumb:hover{background:#00000040}[data-theme=light] .spinner{border-color:var(--color-bg-tertiary);border-top-color:var(--color-accent-green)}[data-theme=light] .skeleton{background:linear-gradient(90deg, var(--color-bg-tertiary) 25%, #c8d2cd80 50%, var(--color-bg-tertiary) 75%)}
