:root{--color-green-50: #f0fdf4;--color-green-100: #dcfce7;--color-green-200: #bbf7d0;--color-green-300: #86efac;--color-green-400: #4ade80;--color-green-500: #22c55e;--color-green-600: #16a34a;--color-green-700: #15803d;--color-green-800: #166534;--color-green-900: #14532d;--color-green-950: #052e16;--color-earth-50: #faf6f1;--color-earth-100: #f0e6d6;--color-earth-200: #e0ccad;--color-earth-300: #cba97a;--color-earth-400: #b8894f;--color-earth-500: #a67639;--color-earth-600: #8c5e2e;--color-earth-700: #724a27;--color-earth-800: #5e3d24;--color-earth-900: #4e3321;--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-primary: var(--color-green-700);--color-primary-light: var(--color-green-500);--color-primary-dark: var(--color-green-900);--color-background: var(--color-gray-50);--color-bg: var(--color-gray-50);--color-surface: #ffffff;--color-text: var(--color-gray-900);--color-text-secondary: var(--color-gray-600);--color-text-muted: var(--color-gray-500);--color-border: var(--color-gray-200);--color-error: #dc2626;--color-danger: #dc2626;--color-success: var(--color-green-600);--color-warning: #f59e0b;--cat-tomatoes: #e53e3e;--cat-peppers: #dd6b20;--cat-herbs: #38a169;--cat-leafy-greens: #2f855a;--cat-root-vegetables: #975a16;--cat-squash: #d69e2e;--cat-legumes: #68d391;--cat-brassicas: #4299e1;--cat-alliums: #9f7aea;--cat-cucurbits: #48bb78;--cat-berries: #e53e3e;--cat-flowers: #ed64a6;--cat-melons: #f6ad55;--cat-corn: #ecc94b;--cat-okra: #68d391;--cat-tropical: #f687b3;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--text-xs: var(--font-size-xs);--text-sm: var(--font-size-sm);--text-base: var(--font-size-base);--text-lg: var(--font-size-lg);--text-xl: var(--font-size-xl);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--surface: var(--color-surface);--surface-hover: var(--color-gray-50);--border: var(--color-border);--primary: var(--color-primary);--danger: var(--color-error);--success: var(--color-success);--text-primary: var(--color-text);--text-muted: var(--color-text-secondary);--text-secondary: var(--color-text-secondary);--primary-light: var(--color-primary-light)}@media(prefers-color-scheme:dark){:root{--color-background: #0f1a0a;--color-bg: #0f1a0a;--color-surface: #1a2614;--color-text: #e8f0e4;--color-text-secondary: #9cb496;--color-text-muted: #7a9a72;--color-border: #2d4a24;--color-primary: var(--color-green-500);--color-primary-light: var(--color-green-400);--color-primary-dark: var(--color-green-700);--color-gray-50: #1a2614;--color-gray-100: #223320;--color-gray-200: #2d4a24;--color-gray-300: #3d6634;--color-gray-400: #5a8a50;--color-gray-500: #7a9a72;--color-gray-600: #9cb496;--color-gray-700: #c0d4bc;--color-gray-800: #dce8d8;--color-gray-900: #e8f0e4;--color-earth-50: #1e1a14;--color-earth-100: #2e2820;--color-earth-200: #4a3e30;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .2);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .3), 0 2px 4px -2px rgb(0 0 0 / .2);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .3), 0 4px 6px -4px rgb(0 0 0 / .2);--surface: var(--color-surface);--surface-hover: #223320;--border: var(--color-border);--text-primary: var(--color-text);--text-muted: var(--color-text-secondary);--text-secondary: var(--color-text-secondary)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-background);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding-top:var(--safe-area-top);padding-bottom:var(--safe-area-bottom);padding-left:var(--safe-area-left);padding-right:var(--safe-area-right)}button,a,select,input[type=checkbox],input[type=radio],.btn,.nav-link,.chip,.task-filter-btn,.scope-btn,.square-chooser-btn,.removal-reason-btn,.rec-variety-item,.variety-picker-item,.variety-card,.planting-list-item,.container-card,.category-card,.overview-card,.dashboard-container-item{min-height:44px;min-width:44px}.btn-sm,.task-card-actions .btn,.time-slider-btn{min-height:36px;min-width:36px}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}html{scroll-behavior:auto}}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--color-green-800),var(--color-green-600));color:#fff;height:56px;position:relative;display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4)}.app-header .header-left{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}@media(min-width:1200px){.app-header{display:block;padding:0}.app-header .header-left{position:absolute;left:var(--space-4);top:50%;transform:translateY(-50%)}.app-header .header-right{position:absolute;right:var(--space-4);top:50%;transform:translateY(-50%)}}.app-header .header-left .tendril-icon{font-size:1.5rem}.app-header .header-left h1{font-size:var(--font-size-xl);font-weight:700}.app-header .header-right{display:flex;align-items:center;gap:var(--space-3)}.app-header .user-name{font-size:var(--font-size-sm);opacity:.9}.app-header .subtitle{font-size:var(--font-size-lg);opacity:.85;margin-top:var(--space-1)}.tendril-icon{font-size:3rem}.app-main{flex:1;padding:var(--space-4);max-width:960px;margin:0 auto;width:100%}.text-muted{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.status-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md);margin-top:var(--space-6)}.status-card h2{font-size:var(--font-size-xl);margin-bottom:var(--space-4);color:var(--color-text)}.status-dot{display:inline-block;width:10px;height:10px;border-radius:var(--radius-full);margin-right:var(--space-2)}.status-dot.ok{background-color:var(--color-success)}.status-dot.error{background-color:var(--color-error)}.status-dot.loading{background-color:var(--color-warning);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-ok,.status-error,.status-loading{display:flex;align-items:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.status-error{color:var(--color-error)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:500;cursor:pointer;border:1px solid transparent;transition:all .15s ease;text-decoration:none;line-height:1.5}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm)}.btn-primary{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-outline{background-color:transparent;color:#fff;border-color:#ffffff80}.btn-outline:hover:not(:disabled){background-color:#ffffff1a;border-color:#fff}.btn-google{background-color:#fff;color:var(--color-gray-700);border-color:var(--color-gray-300);padding:var(--space-3) var(--space-6);font-size:var(--font-size-base);width:100%}.btn-google:hover:not(:disabled){background-color:var(--color-gray-50);box-shadow:var(--shadow-sm)}.btn-google .google-icon{flex-shrink:0}.btn-dev{background-color:var(--color-earth-600);color:#fff;border-color:var(--color-earth-600);white-space:nowrap}.btn-dev:hover:not(:disabled){background-color:var(--color-earth-700)}.btn-danger{background-color:var(--color-error);color:#fff;border-color:var(--color-error)}.btn-danger:hover:not(:disabled){background-color:#b91c1c}.input,.form-input{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family);color:var(--color-text);background-color:var(--color-surface);transition:border-color .15s ease}.input:focus,.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #16a34a26}.input:disabled,.form-input:disabled{background-color:var(--color-gray-100);cursor:not-allowed}textarea.form-input{resize:vertical;min-height:80px;font-family:var(--font-family)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-4);color:var(--color-text-secondary)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:var(--space-4);background:linear-gradient(135deg,var(--color-green-50),var(--color-earth-50))}.login-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-8);box-shadow:var(--shadow-lg);width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-header h1{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-primary);margin-top:var(--space-2)}.login-header .subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:var(--space-1)}.login-actions{display:flex;flex-direction:column;gap:var(--space-4)}.login-divider{display:flex;align-items:center;gap:var(--space-3);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.dev-login-form{display:flex;flex-direction:column;gap:var(--space-2)}.dev-login-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.dev-login-row{display:flex;gap:var(--space-2)}.dev-login-row .input{flex:1}.login-error{background-color:#fef2f2;color:var(--color-error);padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);border:1px solid #fecaca}.app-layout{min-height:100vh;display:flex;flex-direction:column}.tendril-icon-sm{font-size:1.5rem}.header-nav{display:flex;align-items:center;gap:var(--space-1);max-width:960px;width:100%;margin:0 auto;height:100%;padding:0 var(--space-4)}.header-nav-desktop{display:none}@media(min-width:1200px){.header-nav-desktop{display:flex}}.hamburger-btn{display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-md);color:#fff;font-size:1.25rem;width:36px;height:36px;cursor:pointer;line-height:1;transition:background-color .15s ease}.hamburger-btn:hover{background-color:#ffffff26}@media(min-width:1200px){.hamburger-btn{display:none}.header-user-name{display:inline}.header-logout-btn{display:inline-flex}}@media(max-width:1199px){.header-user-name,.header-logout-btn{display:none}}.mobile-menu-overlay{position:fixed;top:56px;right:0;bottom:0;left:0;z-index:200;background:#0006}.mobile-menu{background:linear-gradient(135deg,var(--color-green-800),var(--color-green-700));display:flex;flex-direction:column;padding:var(--space-2) 0 var(--space-4);box-shadow:var(--shadow-lg)}.mobile-menu-user{color:#ffffffb3;font-size:var(--font-size-sm);padding:var(--space-2) var(--space-5);border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:var(--space-2)}.mobile-nav-link{display:block;color:#ffffffd9;text-decoration:none;padding:var(--space-3) var(--space-5);font-size:var(--font-size-base);font-weight:500;transition:background-color .15s ease,color .15s ease;min-height:44px;display:flex;align-items:center}.mobile-nav-link:hover,.mobile-nav-link.active{background-color:#ffffff26;color:#fff}.mobile-menu-logout{margin:var(--space-4) var(--space-5) 0;padding:var(--space-2) var(--space-4);background:transparent;border:1px solid rgba(255,255,255,.4);border-radius:var(--radius-md);color:#fff;font-size:var(--font-size-sm);cursor:pointer;text-align:left;transition:background-color .15s ease;min-height:44px}.mobile-menu-logout:hover{background-color:#ffffff26}.nav-link{display:flex;align-items:center;color:#ffffffb3;text-decoration:none;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;line-height:1;transition:all .15s ease}.nav-link:hover{color:#fff;background-color:#ffffff1a}.nav-link.active{color:#fff;background-color:#fff3}.page-header{margin-bottom:var(--space-6)}.page-header h2{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text)}.page-header .text-muted{margin-top:var(--space-1)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);margin-bottom:var(--space-1)}.form-help{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-1)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-message{padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-4)}.form-message.success{background-color:var(--color-green-50);color:var(--color-green-800);border:1px solid var(--color-green-200)}.form-message.error{background-color:#fef2f2;color:var(--color-error);border:1px solid #fecaca}.settings-page{max-width:560px}.settings-form{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-md)}.location-search-wrapper{position:relative}.location-search-input-row{display:flex;gap:var(--space-2);align-items:stretch}.location-search-input-row .input{flex:1;min-width:0}.location-gps-btn{flex-shrink:0;min-width:44px;font-size:var(--font-size-lg);line-height:1;padding:0 var(--space-3)}.location-gps-btn.loading{opacity:.6;cursor:wait}.location-search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);list-style:none;margin:0;padding:var(--space-1) 0;max-height:240px;overflow-y:auto}.location-search-loading{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.location-search-item{display:flex;flex-direction:column;gap:2px;padding:var(--space-2) var(--space-4);cursor:pointer;transition:background-color .1s ease}.location-search-item:hover{background-color:var(--color-gray-50)}.location-search-item-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text)}.location-search-item-region{font-size:var(--font-size-xs)}.location-confirmed{font-weight:500;color:var(--color-text)}.form-error{font-size:var(--font-size-xs);color:var(--color-red-600, #dc2626);margin-top:var(--space-1)}.account-info{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3);background-color:var(--color-gray-50);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.segmented-control{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.segmented-btn{flex:1;padding:var(--space-2) var(--space-3);background:var(--color-surface);border:none;border-right:1px solid var(--color-border);cursor:pointer;font-size:var(--text-sm);color:var(--color-text-secondary);transition:background var(--transition-fast),color var(--transition-fast)}.segmented-btn:last-child{border-right:none}.segmented-btn:hover{background:var(--color-gray-100);color:var(--color-text)}.segmented-btn.active{background:var(--color-primary);color:#fff;font-weight:500}select.input,select.form-input{-webkit-appearance:none;-moz-appearance:none;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'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-3) center;padding-right:var(--space-8)}.textarea{resize:vertical;min-height:80px;font-family:var(--font-family)}.btn-outline-dark{background-color:transparent;color:var(--color-text);border-color:var(--color-border)}.btn-outline-dark:hover:not(:disabled){background-color:var(--color-gray-100);border-color:var(--color-gray-400)}.back-link{display:inline-block;color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-sm);margin-bottom:var(--space-2);transition:color .15s ease}.back-link:hover{color:var(--color-primary)}.page-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.page-header-actions{display:flex;gap:var(--space-2)}.category-title-row{display:flex;align-items:center;gap:var(--space-3)}.category-color-dot-lg{width:20px;height:20px;border-radius:var(--radius-full);flex-shrink:0}.catalog-page{max-width:900px}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.category-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);border-top:4px solid transparent;text-decoration:none;color:var(--color-text);transition:box-shadow .15s ease,transform .15s ease;display:flex;flex-direction:column;gap:var(--space-3)}.category-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.category-card-icon{font-size:2rem;line-height:1}.category-card-icon svg{width:2rem;height:2rem}.category-emoji{font-size:2rem}.category-card-info h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-1)}.category-card-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.category-card-badge{display:inline-block;font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);margin-top:var(--space-2);font-weight:500;text-transform:capitalize}.empty-state{text-align:center;padding:var(--space-12) var(--space-4);color:var(--color-text-secondary)}.empty-state .empty-icon{font-size:3rem;display:block;margin-bottom:var(--space-4)}.empty-state h3{font-size:var(--font-size-xl);color:var(--color-text);margin-bottom:var(--space-2)}.empty-state p{margin-bottom:var(--space-6)}.empty-state-sm{text-align:center;padding:var(--space-6) var(--space-4);color:var(--color-text-secondary);background:var(--color-gray-50);border-radius:var(--radius-md)}.detail-section{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);margin-bottom:var(--space-4)}.detail-section h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-4)}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.section-header-row h3{margin-bottom:0}.season-list{display:flex;flex-direction:column;gap:var(--space-2)}.season-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-gray-50);border-radius:var(--radius-md)}.season-zone{font-weight:600;font-size:var(--font-size-sm);color:var(--color-primary);min-width:80px}.season-dates{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.companion-group{margin-bottom:var(--space-4)}.companion-group:last-child{margin-bottom:0}.companion-label{font-size:var(--font-size-sm);font-weight:600;margin-bottom:var(--space-2)}.companion-label.good{color:var(--color-success)}.companion-label.bad{color:var(--color-error)}.companion-tags{display:flex;flex-wrap:wrap;gap:var(--space-2)}.companion-tag{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);text-decoration:none;border:1px solid;transition:background-color .15s ease}.companion-tag.good:hover{background-color:var(--color-green-50)}.companion-tag.bad{border-color:var(--color-error);color:var(--color-error)}.companion-tag.bad:hover{background-color:#fef2f2}.variety-list{display:flex;flex-direction:column;gap:var(--space-2)}.variety-card{padding:var(--space-3) var(--space-4);background:var(--color-gray-50);border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s ease}.variety-card:hover{background-color:var(--color-gray-100)}.variety-card-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.variety-card-header h4{font-size:var(--font-size-base);font-weight:600}.variety-badge{font-size:var(--font-size-xs);padding:1px var(--space-2);border-radius:var(--radius-full);background:var(--color-green-100);color:var(--color-green-800)}.variety-badge.climbing{background:var(--color-earth-100);color:var(--color-earth-700)}.variety-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.detail-grid{display:flex;flex-direction:column;gap:var(--space-4)}.detail-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.detail-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-4)}.detail-list{display:flex;flex-direction:column;gap:var(--space-2)}.detail-item{display:flex;justify-content:space-between;align-items:baseline;padding:var(--space-2) 0;border-bottom:1px solid var(--color-gray-100);gap:var(--space-3)}.detail-item:last-child{border-bottom:none}.detail-item dt{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.detail-item dd{font-weight:500;text-transform:capitalize}.detail-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:80px}.detail-value{font-weight:500;text-align:right}.variety-notes{white-space:pre-wrap;color:var(--color-text-secondary);line-height:1.6}.external-link{color:var(--color-primary);text-decoration:none}.external-link:hover{text-decoration:underline}.seed-packet-preview{margin-top:var(--space-3)}.seed-packet-preview img{max-width:100%;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.detail-form{display:flex;flex-direction:column;gap:var(--space-4)}.form-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.form-card h3{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-4)}.form-actions{display:flex;gap:var(--space-3);padding-top:var(--space-2)}.color-input-row{display:flex;gap:var(--space-2);align-items:center}.color-picker{width:44px;height:38px;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;padding:2px;background:var(--color-surface)}.icon-upload-row{display:flex;align-items:center;gap:var(--space-2)}.icon-upload-row .input[type=file]{flex:1}.icon-preview{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-2);padding:var(--space-2);background:var(--color-gray-50);border-radius:var(--radius-md)}.icon-preview-svg{display:inline-flex}.icon-preview-svg svg{width:2rem;height:2rem}.season-form-row{display:grid;grid-template-columns:100px 1fr 1fr auto;gap:var(--space-3);align-items:end;padding:var(--space-3);background:var(--color-gray-50);border-radius:var(--radius-md);margin-bottom:var(--space-3)}.date-row{display:flex;gap:var(--space-2)}.day-input{max-width:70px}.day-select{max-width:72px}.date-preview{display:block;margin-top:var(--space-1);font-size:var(--text-xs);color:var(--color-text-secondary)}.season-remove{margin-bottom:var(--space-5)}.container-list{display:flex;flex-direction:column;gap:var(--space-4)}.container-type-section h2{font-size:var(--text-lg);color:var(--color-text);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.container-type-section h2 .type-icon{font-size:var(--text-xl)}.container-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.container-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);text-decoration:none;color:inherit;transition:box-shadow .15s,border-color .15s}.container-card:hover{border-color:var(--color-primary-light);box-shadow:0 2px 8px #00000014}.container-card h3{font-size:var(--text-base);margin-bottom:var(--space-1)}.container-card .container-meta{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-3)}.container-card .container-meta span+span:before{content:"·";margin:0 var(--space-1)}.grid-preview{display:inline-grid;gap:2px;background:var(--color-gray-200);border-radius:var(--radius-sm);padding:2px;max-width:100%;overflow:hidden}.grid-preview .gp-cell{width:16px;height:16px;background:var(--color-earth-50);border-radius:2px}.grid-preview .gp-cell.has-support{background:var(--color-green-100);border:1px solid var(--color-green-300)}.tower-preview{display:flex;flex-direction:column;gap:3px;align-items:center}.tower-preview .tp-level{display:flex;gap:3px}.tower-preview .tp-pocket{width:14px;height:14px;background:var(--color-earth-100);border-radius:50%;border:1px solid var(--color-earth-300)}.grid-bed-detail{margin:var(--space-4) 0}.grid-bed-wrapper{display:block;background:var(--color-earth-100);border:2px solid var(--color-earth-300);border-radius:var(--radius-md);padding:var(--space-2)}.grid-bed-table{display:grid;gap:4px}.grid-row{display:flex;gap:4px;align-items:center}.grid-row-label{display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);min-width:28px;min-height:28px;flex-shrink:0}.grid-col-label{display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);flex:0 0 calc((100% - 48px)/5);width:calc((100% - 48px)/5);min-width:36px;min-height:28px}.grid-col-labels{display:flex;gap:4px;align-items:center}.grid-square{flex:0 0 calc((100% - 48px)/5);width:calc((100% - 48px)/5);aspect-ratio:1;height:unset;min-width:36px;min-height:36px;background:var(--color-earth-50);border:2px solid var(--color-earth-200);border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);transition:border-color .15s,background .15s;position:relative;overflow:visible}.grid-square:hover{border-color:var(--color-primary-light);background:var(--color-green-50)}.grid-square.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-green-200)}.grid-square.has-support{background:var(--color-green-50);border-color:var(--color-green-300)}.grid-square .support-icon{font-size:var(--text-sm)}.support-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);z-index:200;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 16px #00000040;padding:var(--space-2);min-width:140px;margin-top:var(--space-1);opacity:1}.support-menu button{display:block;width:100%;text-align:left;padding:var(--space-1) var(--space-2);border:none;background:none;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);color:var(--color-text);white-space:nowrap}.support-menu button:hover{background:var(--color-green-50);color:var(--color-primary)}.support-menu button.remove-support{color:var(--color-error)}.support-menu button.remove-support:hover{background:#fef2f2}.tower-detail{margin:var(--space-4) 0}.tower-levels{display:flex;flex-direction:column;gap:var(--space-3);align-items:center}.tower-level{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3);text-align:center;min-width:200px}.tower-level h4{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--space-2)}.tower-pockets{display:flex;gap:var(--space-2);justify-content:center;flex-wrap:wrap}.tower-pocket{width:40px;height:40px;border-radius:50%;background:var(--color-earth-50);border:2px solid var(--color-earth-200);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);color:var(--color-text-secondary)}.container-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-3);margin-bottom:var(--space-4)}.container-info-item{background:var(--color-gray-50);border-radius:var(--radius-md);padding:var(--space-3)}.container-info-item .info-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--space-1)}.container-info-item .info-value{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.type-selector{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-4)}.type-option{border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);text-align:center;cursor:pointer;transition:border-color .15s,background .15s;background:var(--color-surface)}.type-option:hover{border-color:var(--color-primary-light)}.type-option.selected{border-color:var(--color-primary);background:var(--color-green-50)}.type-option .type-emoji{font-size:2rem;margin-bottom:var(--space-2)}.type-option .type-name{font-weight:600;font-size:var(--text-base);margin-bottom:var(--space-1)}.type-option .type-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.irrigation-badge{display:inline-flex;align-items:center;gap:var(--space-1);font-size:var(--text-sm);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);background:#dbeafe;color:#1e40af}.irrigation-badge.none{background:var(--color-gray-100);color:var(--color-text-secondary)}.grid-square.planted{border-style:solid;border-width:2px}.grid-square.not-started{border-style:dashed;opacity:.7}.grid-square.in-progress{border-style:solid}.grid-square.complete{opacity:.5}.grid-square .square-category-icon{display:flex;align-items:center;justify-content:center;width:100%;height:100%;pointer-events:none}.grid-square .square-category-icon svg{width:55%;height:55%;overflow:visible}.grid-square.is-multi-sq{border-color:transparent}.grid-square.is-multi-sq.multi-edge-top{border-top-color:var(--group-color, var(--color-primary));border-top-width:3px;border-top-style:solid}.grid-square.is-multi-sq.multi-edge-bottom{border-bottom-color:var(--group-color, var(--color-primary));border-bottom-width:3px;border-bottom-style:solid}.grid-square.is-multi-sq.multi-edge-left{border-left-color:var(--group-color, var(--color-primary));border-left-width:3px;border-left-style:solid}.grid-square.is-multi-sq.multi-edge-right{border-right-color:var(--group-color, var(--color-primary));border-right-width:3px;border-right-style:solid}.grid-square.is-multi-sq.not-started.multi-edge-top{border-top-style:dashed}.grid-square.is-multi-sq.not-started.multi-edge-bottom{border-bottom-style:dashed}.grid-square.is-multi-sq.not-started.multi-edge-left{border-left-style:dashed}.grid-square.is-multi-sq.not-started.multi-edge-right{border-right-style:dashed}.tower-pocket.planted{border-width:2px}.tower-pocket.not-started{border-style:dashed;opacity:.7}.tower-pocket.in-progress{border-style:solid}.tower-pocket .pocket-variety{font-size:8px;font-weight:700;color:var(--color-text)}.tower-pocket .pocket-label{font-size:var(--text-xs);color:var(--color-text-secondary)}.grid-legend{display:flex;gap:var(--space-4);margin-top:var(--space-3);font-size:var(--text-sm);color:var(--color-text-secondary)}.legend-item{display:flex;align-items:center;gap:var(--space-1)}.legend-swatch{display:inline-block;width:16px;height:16px;border-radius:3px;border:2px solid var(--color-earth-200)}.legend-swatch.fallow{background:var(--color-earth-50)}.legend-swatch.not-started{background:var(--color-green-100);border-style:dashed;border-color:var(--color-green-400);opacity:.7}.legend-swatch.in-progress{background:var(--color-green-200);border-color:var(--color-green-500)}.legend-swatch.complete{background:var(--color-gray-200);border-color:var(--color-gray-400);opacity:.5}.grid-header-row{display:flex;gap:4px;align-items:center}.grid-corner{min-width:28px;min-height:28px}.plantings-list{display:flex;flex-direction:column;gap:var(--space-2)}.planting-list-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s}.planting-list-item:hover{border-color:var(--color-primary-light)}.planting-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.planting-color-dot.inline{display:inline-block;margin-right:var(--space-2);vertical-align:middle}.planting-list-info{flex:1;min-width:0}.planting-list-info strong{display:block;font-size:var(--text-sm)}.planting-list-info .text-muted{font-size:var(--text-xs)}.planting-list-dates{text-align:right;font-size:var(--text-xs);color:var(--color-text-secondary);display:flex;flex-direction:column;gap:var(--space-1);align-items:flex-end}.status-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;text-transform:capitalize}.status-badge.not_started{background:var(--color-gray-100);color:var(--color-gray-600)}.status-badge.in_progress{background:var(--color-green-100);color:var(--color-green-800)}.status-badge.complete{background:var(--color-earth-100);color:var(--color-earth-700)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-4)}.modal-content{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-5);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-content.modal-sm{max-width:420px}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.modal-header h3{font-size:var(--text-lg);margin:0}.modal-close{background:none;border:none;font-size:var(--text-xl);cursor:pointer;color:var(--color-text-secondary);padding:var(--space-1);line-height:1}.modal-close:hover{color:var(--color-text)}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.category-filter-chips{display:flex;flex-wrap:wrap;gap:var(--space-1);margin:var(--space-2) 0}.chip{padding:4px 10px;border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);font-size:var(--text-xs);cursor:pointer;transition:all .15s}.chip:hover{border-color:var(--color-primary-light)}.chip.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.variety-picker-list{max-height:200px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:var(--space-2)}.variety-picker-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);cursor:pointer;transition:background .1s;border-bottom:1px solid var(--color-gray-100)}.variety-picker-item:last-child{border-bottom:none}.variety-picker-item:hover{background:var(--color-green-50)}.variety-picker-item.selected{background:var(--color-green-100);font-weight:600}.variety-picker-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.variety-picker-name{flex:1;font-size:var(--text-sm)}.variety-picker-category{font-size:var(--text-xs);color:var(--color-text-secondary)}.planting-detail-body{margin-bottom:var(--space-2)}.detail-grid.compact{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.detail-grid.compact .detail-item{padding:var(--space-2)}.grid-bed-wrapper{display:flex;flex-direction:column;gap:4px;width:100%}.support-menu-title{font-weight:600;font-size:var(--text-xs);color:var(--color-text-secondary);padding:var(--space-1) var(--space-2);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-1)}@media(max-width:640px){.page-header-row{flex-direction:column;align-items:flex-start}.category-grid,.season-form-row,.form-row{grid-template-columns:1fr}.header-content{flex-wrap:wrap;gap:var(--space-2)}.header-nav{order:3;width:100%;justify-content:center}.container-cards,.type-selector{grid-template-columns:1fr}.grid-square{min-width:32px;min-height:32px;font-size:var(--text-sm)}.container-info-grid{grid-template-columns:1fr}}.lifecycle-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem}.lifecycle-card.planned{border-left:4px solid var(--text-muted)}.lifecycle-card.complete{border-left:4px solid var(--success)}.lifecycle-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.lifecycle-phase-icon{font-size:1.75rem;line-height:1}.lifecycle-info{flex:1}.lifecycle-phase-name{font-weight:600;font-size:var(--text-base);color:var(--text-primary)}.lifecycle-day-count{font-size:var(--text-sm);color:var(--text-muted);margin-top:.125rem}.lifecycle-progress-bar{margin-top:.5rem}.lifecycle-progress-track{width:100%;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.lifecycle-progress-fill{height:100%;border-radius:4px;transition:width .3s ease}.lifecycle-progress-fill.germination{background:linear-gradient(90deg,#68d391,#48bb78)}.lifecycle-progress-fill.growing{background:linear-gradient(90deg,#48bb78,#38a169)}.lifecycle-progress-fill.harvesting{background:linear-gradient(90deg,#ecc94b,#d69e2e)}.lifecycle-progress-label{font-size:var(--text-xs);color:var(--text-muted);margin-top:.375rem;text-align:right}.lifecycle-phase-progress{font-size:var(--text-xs);color:var(--text-muted);margin-top:.25rem}.removal-reason-list{display:flex;flex-direction:column;gap:.5rem}.removal-reason-btn{display:block;width:100%;padding:.75rem 1rem;text-align:left;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-base);cursor:pointer;transition:all .15s ease}.removal-reason-btn:hover{border-color:var(--primary);background:var(--surface-hover)}.removal-reason-btn.selected{border-color:var(--primary);background:#38a16914;font-weight:600}.page-header-actions{display:flex;gap:.5rem;align-items:center}.btn-sm{padding:.375rem .75rem;font-size:var(--text-sm)}.btn-danger{background:var(--danger);color:#fff;border:none;border-radius:var(--radius-md);padding:.5rem 1rem;cursor:pointer;font-weight:500}.btn-danger:hover{opacity:.9}.back-link{display:inline-block;color:var(--text-muted);text-decoration:none;font-size:var(--text-sm);margin-bottom:.5rem}.back-link:hover{color:var(--primary)}.page-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.planting-color-dot.inline{display:inline-block;width:12px;height:12px;border-radius:50%;margin-right:.5rem;vertical-align:middle}.time-slider{display:flex;align-items:center;justify-content:center;gap:.25rem;padding:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:.5rem}.time-slider-btn{background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.35rem .6rem;cursor:pointer;font-size:.9rem;line-height:1;transition:background .15s,border-color .15s}.time-slider-btn:hover{background:var(--color-green-50);border-color:var(--color-green-300)}.time-slider-date{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.35rem .5rem;font-size:var(--text-sm);font-family:inherit;text-align:center;min-width:140px}.time-slider-date:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-green-100)}.time-slider-today{background:var(--color-green-600);color:#fff;border:none;border-radius:var(--radius-md);padding:.35rem .75rem;cursor:pointer;font-size:var(--text-sm);font-weight:500;margin-left:.5rem;transition:background .15s}.time-slider-today:hover{background:var(--color-green-700)}.time-slider-label{text-align:center;font-size:var(--text-sm);padding:.35rem .75rem;border-radius:var(--radius-md);margin-bottom:var(--space-3)}.time-slider-label.past{background:var(--color-earth-100);color:var(--color-earth-700)}.time-slider-label.future{background:#ede9fe;color:#6d28d9}.overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.overview-card{display:flex;flex-direction:column;gap:.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}.overview-card:hover{border-color:var(--color-green-300);box-shadow:0 2px 8px #00000014}.overview-card-header{display:flex;justify-content:space-between;align-items:center}.overview-card-header h3{margin:0;font-size:var(--text-base)}.overview-stats{font-size:var(--text-sm);color:var(--color-text-secondary);white-space:nowrap}.overview-location{font-size:var(--text-xs);color:var(--color-text-secondary)}.mini-grid{display:grid;gap:2px;padding:.25rem;background:var(--color-gray-100);border-radius:var(--radius-sm)}.mini-square{aspect-ratio:1;border-radius:2px;border:1px solid var(--color-gray-200);min-width:0;min-height:0}.mini-square.empty{background:var(--color-gray-50)}.mini-square.planted{border-width:1.5px}.mini-tower{display:flex;flex-direction:column;gap:3px;padding:.25rem;background:var(--color-gray-100);border-radius:var(--radius-sm)}.mini-tower-level{display:flex;gap:3px}.mini-pocket{flex:1;height:18px;border-radius:9px;border:1px solid var(--color-gray-200)}.mini-pocket.empty{background:var(--color-gray-50)}.mini-pocket.planted{border-width:1.5px}.overview-legend{display:flex;flex-wrap:wrap;gap:.5rem;padding-top:.25rem}.overview-legend-item{display:flex;align-items:center;gap:.25rem;font-size:var(--text-xs);color:var(--color-text-secondary)}.overview-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.square-chooser-actions{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4)}.square-chooser-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;text-align:center}.square-chooser-btn:hover{border-color:var(--color-green-400);background:var(--color-green-50);box-shadow:0 2px 8px #0000000f}.chooser-icon{font-size:2rem;line-height:1}.chooser-label{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.chooser-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.rec-results{padding:var(--space-3) var(--space-4) var(--space-4);max-height:60vh;overflow-y:auto}.rec-category{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-2);overflow:hidden}.rec-category-header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:none;background:var(--color-gray-50);cursor:pointer;font-size:var(--text-base);text-align:left;transition:background .15s}.rec-category-header:hover{background:var(--color-gray-100)}.rec-category-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.rec-category-name{flex:1;font-weight:600}.rec-category-count{font-size:var(--text-sm);color:var(--color-text-secondary);background:var(--color-gray-200);padding:.1rem .5rem;border-radius:999px}.rec-category-arrow{font-size:var(--text-xs);color:var(--color-text-secondary);margin-left:.25rem}.rec-variety-list{border-top:1px solid var(--color-border)}.rec-variety-item{padding:.75rem 1rem;border-bottom:1px solid var(--color-gray-100);cursor:pointer;transition:background .15s}.rec-variety-item:last-child{border-bottom:none}.rec-variety-item:hover{background:var(--color-green-50)}.rec-variety-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.rec-score{font-size:var(--text-sm);font-weight:600;color:var(--color-green-700);background:var(--color-green-50);padding:.1rem .5rem;border-radius:var(--radius-sm);white-space:nowrap}.rec-variety-meta{display:flex;flex-wrap:wrap;gap:.75rem;font-size:var(--text-xs);color:var(--color-text-secondary);margin-bottom:.25rem}.rec-boosts{display:flex;flex-direction:column;gap:.15rem;margin-top:.25rem}.rec-boost{font-size:var(--text-xs);color:var(--color-green-700)}.rec-warnings{display:flex;flex-direction:column;gap:.15rem;margin-top:.25rem}.rec-warning{font-size:var(--text-xs);color:var(--color-earth-700)}.timeline-controls{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4)}.timeline-scope-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.scope-btn{padding:.4rem 1rem;border:none;background:var(--color-surface);cursor:pointer;font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);transition:background .15s,color .15s}.scope-btn:not(:last-child){border-right:1px solid var(--color-border)}.scope-btn.active{background:var(--color-green-600);color:#fff}.scope-btn:hover:not(.active){background:var(--color-gray-100)}.timeline-filter .form-select{padding:.4rem .75rem;font-size:var(--text-sm);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface)}.timeline-date-info{display:flex;align-items:center;gap:.75rem;margin-left:auto}.timeline-today-badge{font-size:var(--text-xs);background:#e53e3e;color:#fff;padding:.15rem .5rem;border-radius:999px;font-weight:500}.gantt-wrapper{display:flex;flex-direction:column;gap:var(--space-3)}.gantt-scroll-container{overflow-x:auto;overflow-y:auto;max-height:70vh;border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);-webkit-overflow-scrolling:touch}.gantt-svg{display:block}.gantt-legend{display:flex;flex-wrap:wrap;gap:1rem;padding:.5rem 0;font-size:var(--text-xs);color:var(--color-text-secondary)}.gantt-legend-item{display:flex;align-items:center;gap:.35rem}.gantt-legend-swatch{width:16px;height:12px;border-radius:2px;border:1px solid var(--color-gray-300)}.gantt-legend-dashed{background:var(--color-gray-200);border:1px dashed var(--color-gray-500)}.gantt-legend-line{width:16px;height:2px;background:#e53e3e}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center;color:var(--color-text-secondary)}.empty-state h3{margin:var(--space-2) 0 var(--space-1);color:var(--color-text)}.empty-state p{margin:0}.activity-timeline{margin-top:var(--space-4)}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.timeline-header h3{margin:0;font-size:1.1rem}.timeline-list{display:flex;flex-direction:column;gap:var(--space-2)}.timeline-item{display:flex;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);position:relative}.timeline-item-icon{font-size:1.4rem;flex-shrink:0;width:2rem;text-align:center}.timeline-item-content{flex:1;min-width:0}.timeline-item-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.timeline-item-title{font-weight:600;font-size:.9rem}.timeline-item-date{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap}.timeline-item-text{font-size:.85rem;color:var(--color-text-muted);margin:0;line-height:1.4;white-space:pre-wrap}.timeline-item-delete{position:absolute;top:var(--space-2);right:var(--space-2);background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:1.2rem;padding:0 var(--space-1);opacity:0;transition:opacity .15s}.timeline-item:hover .timeline-item-delete{opacity:.6}.timeline-item-delete:hover{opacity:1!important;color:var(--color-danger)}.harvest-summary{margin-top:var(--space-4);padding:var(--space-3);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.harvest-summary h3{margin:0 0 var(--space-2);font-size:1rem}.harvest-totals{display:flex;gap:var(--space-2);flex-wrap:wrap}.harvest-total-badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-2);background:var(--color-primary-light);color:var(--color-primary-dark);border-radius:var(--radius-full);font-size:.85rem;font-weight:600}.photo-import-card{border:2px dashed var(--border);background:var(--color-green-50)}.photo-import-buttons{display:flex;gap:var(--space-3);flex-wrap:wrap}.photo-import-buttons .btn{flex:1;min-width:160px}.extract-loading{display:flex;align-items:center;gap:var(--space-3);margin-top:var(--space-3);padding:var(--space-3);background:var(--surface);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.9rem}.extract-spinner{width:20px;height:20px;border:3px solid var(--border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.photo-preview{display:flex;align-items:flex-start}.seed-packet-photo{margin-top:var(--space-4)}.seed-packet-photo img{max-width:300px;max-height:300px;border-radius:var(--radius-md);border:1px solid var(--border);object-fit:cover;cursor:pointer;transition:transform .2s}.seed-packet-photo img:hover{transform:scale(1.02)}.task-filters{display:flex;gap:var(--space-2);margin-bottom:var(--space-6);border-bottom:2px solid var(--color-border);padding-bottom:var(--space-2)}.task-filter-btn{padding:var(--space-2) var(--space-4);border:none;background:none;color:var(--color-text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.task-filter-btn:hover{color:var(--color-text)}.task-filter-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.task-groups{display:flex;flex-direction:column;gap:var(--space-6)}.task-group-label{font-size:.95rem;font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.task-group-count{background:var(--color-gray-200);color:var(--color-gray-600);font-size:.75rem;font-weight:600;padding:2px 8px;border-radius:10px}.task-list{display:flex;flex-direction:column;gap:var(--space-2)}.task-card{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color .2s,box-shadow .2s}.task-card:hover{border-color:var(--color-gray-300);box-shadow:0 1px 4px #0000000f}.task-card.task-overdue{border-left:3px solid var(--color-error);background:#fef2f2}.task-card.task-today{border-left:3px solid var(--color-primary);background:var(--color-green-50)}.task-card.task-done{opacity:.6;background:var(--color-gray-50)}.task-card.task-done .task-title{text-decoration:line-through}.task-card-main{flex:1;min-width:0}.task-card-header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-1)}.task-source-badge{font-size:.85rem;flex-shrink:0}.task-title{font-size:.95rem;font-weight:600;color:var(--color-text);margin:0}.task-description{font-size:.85rem;color:var(--color-text-secondary);margin:var(--space-1) 0 0 0;line-height:1.4}.task-meta{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-2);font-size:.8rem;color:var(--color-text-secondary)}.task-due{color:var(--color-text-secondary)}.task-overdue .task-due{color:var(--color-error);font-weight:600}.task-link{color:var(--color-primary);text-decoration:none}.task-link:hover{text-decoration:underline}.task-variety{color:var(--color-text-secondary)}.task-card-actions{display:flex;gap:var(--space-1);flex-shrink:0;align-items:flex-start}.task-card-actions .btn{padding:4px 8px;font-size:.8rem;min-width:32px}.btn-success{background:var(--color-success);color:#fff;border:1px solid var(--color-success)}.btn-success:hover{background:var(--color-green-700);border-color:var(--color-green-700)}.btn-danger{background:transparent;color:var(--color-error);border:1px solid var(--color-error)}.btn-danger:hover{background:var(--color-error);color:#fff}.text-error{color:var(--color-error)}.text-secondary{color:var(--color-text-secondary)}.page-subtitle{font-size:.9rem;color:var(--color-text-secondary);margin-top:var(--space-1)}.page-actions{display:flex;gap:var(--space-2);align-items:center}.weather-widget{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.weather-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4)}.weather-header-title{display:flex;flex-direction:column;gap:var(--space-1)}.weather-header h3{margin:0;font-size:1rem;font-weight:600}.weather-city-name{font-size:.78rem;color:var(--color-text-secondary)}.weather-config-link{font-size:.8rem;color:var(--color-primary);text-decoration:none}.weather-config-link:hover{text-decoration:underline}.weather-forecast{display:flex;gap:var(--space-2);overflow-x:auto;-webkit-overflow-scrolling:touch}.weather-day{flex:1;min-width:80px;display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);border-radius:var(--radius-md);background:var(--color-gray-50);text-align:center}.weather-day-today{background:var(--color-green-50);border:1px solid var(--color-green-200)}.weather-day-name{font-size:.8rem;font-weight:600;color:var(--color-text)}.weather-day-date{font-size:.7rem;color:var(--color-text-secondary)}.weather-day-icon{font-size:1.5rem;line-height:1}.weather-day-temps{display:flex;gap:var(--space-1);font-size:.85rem}.weather-temp-high{font-weight:600;color:var(--color-text)}.weather-temp-low{color:var(--color-text-secondary)}.weather-day-rain{font-size:.7rem;color:#3b82f6}.weather-loading,.weather-error{text-align:center;padding:var(--space-4);color:var(--color-text-secondary);font-size:.9rem}.dashboard-greeting{margin-bottom:var(--space-4)}.dashboard-greeting h2{font-size:1.5rem;font-weight:700;margin-bottom:var(--space-1)}.dashboard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-4)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3);text-align:center}.stat-card-btn{cursor:pointer;transition:all .15s ease;font-family:inherit;width:100%}.stat-card-btn:hover{background:var(--color-green-50);border-color:var(--color-primary);box-shadow:0 2px 8px #15803d26;transform:translateY(-1px)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.stat-label{font-size:.8rem;color:var(--color-text-secondary);margin-top:var(--space-1)}.stat-sub{font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-1)}.dashboard-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-bottom:var(--space-4)}.quick-action-btn{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);text-decoration:none;font-size:.85rem;font-weight:500;transition:all .15s ease}.quick-action-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.dashboard-grid{display:grid;grid-template-columns:1fr 320px;gap:var(--space-4);align-items:start}.dashboard-column{display:flex;flex-direction:column;gap:var(--space-4)}.dashboard-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.dashboard-card-alert{border-color:var(--color-error, #ef4444);background:#fef2f2}.dashboard-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.dashboard-card-title{font-size:1rem;font-weight:600;margin:0}.dashboard-card-link{font-size:.8rem;color:var(--color-primary);text-decoration:none}.dashboard-card-link:hover{text-decoration:underline}.dashboard-task-list{display:flex;flex-direction:column;gap:var(--space-2)}.dashboard-task-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2);border-radius:var(--radius-md);background:var(--color-bg)}.dashboard-task-item.task-overdue{background:#fee2e2}.dashboard-task-info{display:flex;align-items:flex-start;gap:var(--space-2);flex:1;min-width:0}.dashboard-task-source{font-size:1rem;flex-shrink:0;margin-top:2px}.dashboard-task-title{font-size:.9rem;font-weight:500;color:var(--color-text)}.dashboard-task-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);font-size:.75rem;color:var(--color-text-secondary);margin-top:2px}.dashboard-task-meta a{color:var(--color-primary);text-decoration:none}.dashboard-task-meta a:hover{text-decoration:underline}.dashboard-container-list{display:flex;flex-direction:column;gap:var(--space-2)}.dashboard-container-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);background:var(--color-bg);text-decoration:none;color:var(--color-text);transition:background .15s ease}.dashboard-container-item:hover{background:var(--color-border)}.dashboard-container-info{display:flex;align-items:center;gap:var(--space-2);flex:1;min-width:0}.dashboard-container-icon{font-size:1.2rem;flex-shrink:0}.dashboard-container-name{font-size:.9rem;font-weight:500}.dashboard-container-meta{font-size:.75rem;color:var(--color-text-secondary)}.dashboard-container-bar{width:60px;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden;flex-shrink:0}.dashboard-container-bar-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.dashboard-empty{text-align:center;padding:var(--space-4);color:var(--color-text-secondary);font-size:.9rem}.dashboard-empty .btn{margin-top:var(--space-2)}@media(max-width:768px){.dashboard-stats{grid-template-columns:repeat(3,1fr)}.dashboard-grid{grid-template-columns:1fr}.dashboard-column-side{order:-1}}.notification-prompt{background:var(--color-surface);border:1px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3)}.notification-prompt-content{display:flex;align-items:flex-start;gap:var(--space-2)}.notification-prompt-icon{font-size:1.5rem;flex-shrink:0}.notification-prompt-text strong{display:block;font-size:.9rem;margin-bottom:2px}.notification-prompt-text p{font-size:.8rem;color:var(--color-text-secondary);margin:0}.notification-prompt-actions{display:flex;gap:var(--space-2)}@supports (padding: env(safe-area-inset-top)){.app-header{padding-top:env(safe-area-inset-top)}.app-layout{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.page-container{padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom))}}@media(display-mode:standalone){html{overscroll-behavior-y:contain}body{overscroll-behavior-y:contain;-webkit-overflow-scrolling:touch}}@media(display-mode:standalone){.app-header{border-bottom-width:2px}}@media(max-width:480px){.dashboard-stats{grid-template-columns:repeat(3,1fr);gap:var(--space-2)}.stat-card{padding:var(--space-2)}.stat-value{font-size:1.2rem}.dashboard-actions{gap:var(--space-1)}.quick-action-btn{padding:var(--space-1) var(--space-2);font-size:.8rem}}.tendril-motif{display:inline-block;width:120px;height:24px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 24'%3E%3Cpath d='M2 22 C10 22 15 12 25 12 S40 22 50 22 S65 2 75 2 S90 22 100 22 S115 12 118 8' fill='none' stroke='%2316a34a' stroke-width='2' stroke-linecap='round'/%3E%3Ccircle cx='118' cy='8' r='3' fill='%2322c55e'/%3E%3Ccircle cx='75' cy='2' r='2' fill='%2322c55e'/%3E%3C/svg%3E") no-repeat center;opacity:.5}.tendril-motif-lg{display:block;width:200px;height:40px;margin:var(--space-4) auto;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 40'%3E%3Cpath d='M5 35 C20 35 25 10 45 10 S70 35 90 35 S115 5 135 5 S160 35 180 35 S195 15 198 10' fill='none' stroke='%2316a34a' stroke-width='2.5' stroke-linecap='round'/%3E%3Ccircle cx='45' cy='10' r='3' fill='%2322c55e'/%3E%3Ccircle cx='135' cy='5' r='4' fill='%2322c55e'/%3E%3Ccircle cx='198' cy='10' r='3' fill='%2322c55e'/%3E%3Cpath d='M45 10 C42 4 38 2 34 4' fill='none' stroke='%2386efac' stroke-width='1.5' stroke-linecap='round'/%3E%3Cpath d='M135 5 C138 -1 142 -2 146 0' fill='none' stroke='%2386efac' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center;opacity:.4}.login-card:after{content:"";display:block;width:100%;height:32px;margin-top:var(--space-6);background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 300 32'%3E%3Cpath d='M0 28 C30 28 40 8 70 8 S110 28 140 28 S180 4 210 4 S250 28 280 28 L300 28' fill='none' stroke='%2316a34a' stroke-width='1.5' stroke-linecap='round' opacity='0.3'/%3E%3Ccircle cx='70' cy='8' r='2.5' fill='%2322c55e' opacity='0.4'/%3E%3Ccircle cx='210' cy='4' r='2.5' fill='%2322c55e' opacity='0.4'/%3E%3C/svg%3E") no-repeat center bottom;background-size:contain}.app-header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:4px;background:linear-gradient(90deg,transparent 0%,var(--color-green-400) 15%,var(--color-green-300) 30%,var(--color-green-500) 50%,var(--color-green-300) 70%,var(--color-green-400) 85%,transparent 100%);opacity:.6}.app-header{position:relative}.app-main{animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.category-card,.container-card,.overview-card,.dashboard-card,.detail-card,.form-card,.settings-form{transition:box-shadow var(--transition-normal),transform var(--transition-normal),border-color var(--transition-fast)}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-md)}.skeleton-text{height:1em;margin-bottom:var(--space-2);border-radius:var(--radius-sm)}.skeleton-text.short{width:60%}.skeleton-text.medium{width:80%}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-circle{width:40px;height:40px;border-radius:50%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-spinner{display:inline-block;width:24px;height:24px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner.lg{width:40px;height:40px;border-width:4px}.loading-center{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);gap:var(--space-3);color:var(--color-text-secondary)}.error-state{text-align:center;padding:var(--space-8) var(--space-4);color:var(--color-text-secondary)}.error-state .error-icon{font-size:3rem;display:block;margin-bottom:var(--space-4)}.error-state h3{font-size:var(--font-size-xl);color:var(--color-error);margin-bottom:var(--space-2)}.error-state p{margin-bottom:var(--space-4)}.error-state .btn{margin-top:var(--space-2)}.empty-state .tendril-motif-lg{margin-bottom:var(--space-2)}.toast{position:fixed;bottom:calc(var(--space-4) + var(--safe-area-bottom));left:50%;transform:translate(-50%) translateY(100px);background:var(--color-gray-900);color:#fff;padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:500;box-shadow:var(--shadow-lg);z-index:200;opacity:0;transition:transform .3s ease,opacity .3s ease;max-width:calc(100vw - var(--space-8))}.toast.show{transform:translate(-50%) translateY(0);opacity:1}.toast.toast-success{background:var(--color-green-800)}.toast.toast-error{background:var(--color-error)}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600;line-height:1.4}.badge-primary{background:var(--color-green-100);color:var(--color-green-800)}.badge-warning{background:#fef3c7;color:#92400e}.badge-error{background:#fee2e2;color:#991b1b}.badge-info{background:#dbeafe;color:#1e40af}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}::selection{background:var(--color-green-200);color:var(--color-green-900)}@media(prefers-color-scheme:dark){.app-header{background:linear-gradient(135deg,#0a2e0a,#14532d)}.app-header:after{opacity:.3}.login-page{background:linear-gradient(135deg,#0a2e0a,#1a2614)}.login-card{box-shadow:0 10px 15px -3px #0006}.login-error,.form-message.error{background-color:#2d1515;border-color:#5c2020}.form-message.success{background-color:#0a2e0a;border-color:#14532d}.task-card.task-overdue{background:#2d1515;border-left-color:var(--color-error)}.task-card.task-today{background:#0a2e0a}.dashboard-card-alert{background:#2d1515;border-color:#5c2020}.dashboard-task-item.task-overdue{background:#2d1515}.time-slider-label.past{background:var(--color-earth-100);color:var(--color-earth-200)}.time-slider-label.future{background:#1e1040;color:#a78bfa}.irrigation-badge{background:#1e3a5f;color:#93c5fd}.skeleton{background:linear-gradient(90deg,var(--color-gray-200) 25%,var(--color-gray-100) 50%,var(--color-gray-200) 75%);background-size:200% 100%}.toast{background:var(--color-gray-100);color:var(--color-text)}::-webkit-scrollbar-thumb{background:var(--color-gray-400)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}::selection{background:var(--color-green-900);color:var(--color-green-100)}.btn-google{background-color:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-google:hover:not(:disabled){background-color:var(--color-gray-100)}.companion-tag.bad:hover{background-color:#2d1515}.photo-import-card{background:#0a2e0a;border-color:var(--color-border)}img{opacity:.92}}@media(max-width:390px){.app-main{padding:var(--space-3)}.page-header h2{font-size:var(--font-size-xl)}.dashboard-greeting h2{font-size:1.25rem}.weather-forecast{gap:var(--space-1)}.weather-day{min-width:64px;padding:var(--space-2) var(--space-1)}.modal-content{padding:var(--space-3);margin:var(--space-2)}.form-row{grid-template-columns:1fr}.nav-link{padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs)}.header-right .user-name{display:none}.grid-square{min-width:28px;min-height:28px;font-size:.7rem}.gantt-scroll-container{max-height:50vh}}@media(max-width:640px)and (display-mode:standalone){.app-header{position:sticky;top:0;z-index:50}.header-nav{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--space-1) var(--space-2);padding-bottom:calc(var(--space-1) + var(--safe-area-bottom));z-index:50;justify-content:space-around;gap:0}.header-nav .nav-link{color:var(--color-text-secondary);font-size:var(--font-size-xs);padding:var(--space-1);flex-direction:column;gap:2px;text-align:center;border-radius:var(--radius-sm)}.header-nav .nav-link.active{color:var(--color-primary);background:var(--color-green-50)}.header-nav .nav-link:hover{color:var(--color-primary);background:transparent}.app-main{padding-bottom:calc(var(--space-8) + 60px + var(--safe-area-bottom))}}@media print{.app-header,.header-nav,.btn,.notification-prompt,.modal-overlay{display:none!important}.app-main{padding:0;max-width:100%}body{background:#fff;color:#000}.detail-card,.form-card,.dashboard-card{box-shadow:none;border:1px solid #ccc}}
