@charset "UTF-8";.badge-unlock-overlay{position:fixed;inset:0;z-index:10000;background:#0009;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confetti-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.badge-unlock-modal{position:relative;z-index:1;background:var(--card-bg, #fff);border-radius:20px;padding:2rem;max-width:380px;width:90%;text-align:center;animation:badgeSlideUp .4s ease-out;border:2px solid var(--rarity-color, #94a3b8)}@keyframes badgeSlideUp{0%{opacity:0;transform:translateY(40px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.badge-unlock-header{margin-bottom:1rem}.badge-unlock-label{font-size:1.2rem;font-weight:700;color:var(--text-primary, #1a1a2e)}.badge-unlock-icon-wrapper{display:flex;justify-content:center;margin:1rem 0}.badge-unlock-icon{width:80px;height:80px;border-radius:50%;background:var(--bg-secondary, #f8f9fa);display:flex;align-items:center;justify-content:center;font-size:2.5rem;animation:badgePulse 1.5s ease-in-out infinite}@keyframes badgePulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.badge-unlock-name{font-size:1.4rem;font-weight:700;color:var(--text-primary, #1a1a2e);margin:.5rem 0 .25rem}.badge-unlock-desc{color:var(--text-secondary, #6b7280);font-size:.9rem;margin-bottom:.75rem}.badge-rarity-chip{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:600;margin-bottom:1.5rem}.badge-unlock-actions{display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}.badge-unlock-actions button{padding:.5rem 1rem;border-radius:10px;border:none;font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .15s}.badge-unlock-actions button:hover{transform:translateY(-1px)}.btn-badge-view{background:var(--primary, #22c55e);color:#fff}.btn-badge-share{background:var(--bg-secondary, #f1f5f9);color:var(--text-primary, #1a1a2e)}.btn-badge-continue{background:transparent;color:var(--text-secondary, #6b7280)}.app-switcher{position:relative}.app-switcher .app-switcher-btn{display:flex;align-items:center;gap:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:var(--radius-lg);cursor:pointer;color:var(--text-primary);font-weight:500;transition:all .2s ease}.app-switcher .app-switcher-btn:hover{background:var(--bg-tertiary);border-color:var(--primary)}.app-switcher .app-switcher-btn span:first-child{font-size:1.25rem}.app-switcher .app-switcher-btn-menu{width:100%;padding:.875rem 1.25rem;background:transparent;border:none;color:#fff;font-size:1rem;cursor:pointer;transition:all .3s ease;text-align:left;display:flex;align-items:center;gap:.5rem;border-radius:8px}.app-switcher .app-switcher-btn-menu:hover{background-color:#ffffff1a;transform:translate(2px)}.app-switcher .app-switcher-overlay{position:fixed;inset:0;background:#0f1e3abf;z-index:10000;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-switcher .app-switcher-modal{position:fixed;top:0;right:0;width:420px;max-width:90vw;max-height:85vh;background:var(--card-bg);border:2px solid var(--border-color);border-radius:20px;box-shadow:0 25px 50px #00000080;z-index:10001;overflow:hidden;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.app-switcher .app-switcher-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}.app-switcher .app-switcher-modal .modal-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--primary);text-shadow:0 0 10px rgba(102,175,233,.3)}.app-switcher .app-switcher-modal .modal-header .modal-close{background:var(--bg-tertiary);border:2px solid var(--border-color);color:var(--text-primary);font-size:18px;width:36px;height:36px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .25s ease;font-weight:300}.app-switcher .app-switcher-modal .modal-header .modal-close:hover{background:var(--danger);border-color:var(--danger);color:#fff;transform:rotate(90deg)}.app-switcher .app-switcher-modal .modal-description{padding:16px 24px;margin:0;font-size:.875rem;color:var(--text-secondary);text-align:center;background:var(--bg-primary)}.app-switcher .app-switcher-modal .app-list{flex:1;overflow-y:auto;padding:16px;background:var(--bg-primary)}.app-switcher .app-switcher-modal .app-list .app-item{display:flex;align-items:center;gap:16px;padding:16px;margin-bottom:12px;background:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .25s ease;width:100%;text-align:left}.app-switcher .app-switcher-modal .app-list .app-item:hover:not(.current){background:var(--bg-secondary);border-color:var(--primary);transform:translateY(-2px);box-shadow:0 8px 16px #0003}.app-switcher .app-switcher-modal .app-list .app-item.current{background:linear-gradient(135deg,var(--primary-dark) 0%,var(--primary) 100%);border-color:var(--primary);cursor:default;box-shadow:0 4px 12px #66afe94d}.app-switcher .app-switcher-modal .app-list .app-item .app-logo{width:56px;height:56px;border-radius:12px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:2rem;overflow:hidden;border:2px solid var(--border-color)}.app-switcher .app-switcher-modal .app-list .app-item .app-logo img{width:100%;height:100%;object-fit:cover}.app-switcher .app-switcher-modal .app-list .app-item .app-logo span{font-size:2rem}.app-switcher .app-switcher-modal .app-list .app-item .app-info{flex:1;min-width:0}.app-switcher .app-switcher-modal .app-list .app-item .app-info .app-name{display:flex;align-items:center;gap:8px;margin-bottom:4px;font-weight:700;font-size:1rem;color:var(--text-primary)}.app-switcher .app-switcher-modal .app-list .app-item .app-info .app-name .current-badge{background:#fff3;color:#fff;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.app-switcher .app-switcher-modal .app-list .app-item .app-info .app-description{font-size:.875rem;color:var(--text-secondary);line-height:1.4}.app-switcher .app-switcher-modal .app-list .app-item .app-action{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--primary);border-radius:50%;color:#fff;font-size:1.25rem;transition:all .25s ease;flex-shrink:0}.app-switcher .app-switcher-modal .app-list .app-item .app-action .arrow{display:block;transform:translate(0);transition:transform .25s ease}.app-switcher .app-switcher-modal .app-list .app-item:hover:not(.current) .app-action{background:var(--primary-light);transform:scale(1.1)}.app-switcher .app-switcher-modal .app-list .app-item:hover:not(.current) .app-action .arrow{transform:translate(3px)}.app-switcher .app-switcher-modal .app-list .app-item.current .app-info .app-name,.app-switcher .app-switcher-modal .app-list .app-item.current .app-info .app-description{color:#fff}@keyframes modalSlideIn{0%{opacity:0;transform:translate(-50%,-45%)}to{opacity:1;transform:translate(-50%,-50%)}}@media(max-width:768px){.app-switcher .app-switcher-modal{width:95vw;max-height:90vh}.app-switcher .app-switcher-modal .app-list .app-item{padding:12px}.app-switcher .app-switcher-modal .app-list .app-item .app-logo{width:48px;height:48px}.app-switcher .app-switcher-modal .app-list .app-item .app-info .app-name{font-size:.9rem}}.navbar{position:fixed;top:0;left:0;right:0;height:var(--navbar-height);background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 2rem;z-index:100;box-shadow:var(--shadow-sm)}.navbar__brand{display:flex;align-items:center;gap:.75rem}.navbar__logo{color:var(--primary);font-size:2rem}.navbar__title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.navbar__links{display:flex;align-items:center;gap:2rem;margin-left:auto;margin-right:auto}.navbar__link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:1rem;transition:color .2s ease}.navbar__link:hover{color:var(--primary)}.navbar__actions{display:flex;align-items:center;gap:1rem}.navbar__icon-btn{position:relative;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:all .2s ease}.navbar__icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.navbar__icon-btn .badge{position:absolute;top:.25rem;right:.25rem;background:var(--danger);color:#fff;font-size:.625rem;font-weight:600;padding:.125rem .375rem;border-radius:999px}.navbar__user-menu{position:relative}.navbar__user-menu--open .navbar__dropdown{opacity:1;visibility:visible;transform:translateY(0)}.navbar__user-btn{display:flex;align-items:center;gap:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);padding:.5rem 1rem;border-radius:var(--radius-lg);cursor:pointer;color:var(--text-primary);font-weight:500;transition:all .2s ease}.navbar__user-btn:hover{background:var(--bg-tertiary);border-color:var(--primary)}.navbar__dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .2s ease;overflow:visible}.navbar__dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:var(--text-primary);text-decoration:none;cursor:pointer;transition:background .2s ease}.navbar__dropdown-item:hover{background:var(--bg-secondary)}.navbar__dropdown-item--danger{color:#e53935}.navbar__dropdown-item--danger:hover{background:#e5393514}.navbar__dropdown-divider{height:1px;margin:.25rem 0;background:var(--border-color)}.navbar__dropdown-switcher{padding:0}.navbar__dropdown-switcher .app-switcher .app-switcher-btn-menu{width:100%;padding:.75rem 1rem;background:transparent;border:none;color:var(--text-primary);font-size:1rem;cursor:pointer;transition:all .2s ease;text-align:left;display:flex;align-items:center;gap:.75rem;border-radius:0}.navbar__dropdown-switcher .app-switcher .app-switcher-btn-menu:hover{background:var(--bg-secondary);transform:none}.navbar__hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:6px;background:none;border:none;cursor:pointer;border-radius:var(--radius-md);transition:background .2s ease}.navbar__hamburger:hover{background:var(--bg-secondary)}.navbar__hamburger span{display:block;width:100%;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}@media(max-width:768px){.navbar{padding:0 .75rem;gap:.5rem}.navbar__hamburger{display:flex;flex-shrink:0}.navbar__brand{flex:1;min-width:0}.navbar__logo{font-size:1.5rem}.navbar__title{font-size:1.1rem}.navbar__links{display:none}.navbar__actions{gap:.5rem;flex-shrink:0}.navbar__icon-btn{padding:.375rem}.navbar__user-btn{padding:.375rem .5rem}.navbar__user-btn span:last-child{display:none}}.premium-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease;will-change:opacity}.premium-modal{background:var(--card-bg);border-radius:var(--radius-xl);padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:var(--shadow-xl);animation:slideUp .2s ease;will-change:transform,opacity}.premium-modal__close{position:absolute;top:1rem;right:1rem;background:var(--bg-secondary);border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;color:var(--text-secondary);transition:background-color .15s ease,color .15s ease}.premium-modal__close:hover{background:var(--danger);color:#fff}.premium-modal__header{text-align:center;margin-bottom:2rem}.premium-modal__crown{font-size:4rem;margin-bottom:1rem;animation:bounce .8s ease 2}.premium-modal h2{font-size:1.75rem;color:var(--text-primary);margin-bottom:.5rem;background:linear-gradient(135deg,#f093fb,#f5576c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.premium-modal__subtitle{color:var(--text-secondary);font-size:.95rem}.premium-modal__teaser{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.premium-modal__teaser h3{font-size:1.1rem;color:var(--text-primary);margin-bottom:1rem}.premium-modal__features{list-style:none;display:grid;grid-template-columns:1fr;gap:.75rem}.premium-modal__features li{font-size:.9rem;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem}.premium-modal__features li:before{content:"✓";background:var(--primary);color:#fff;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0}.premium-modal__pricing{text-align:center;padding:1.5rem 0;border-top:1px solid var(--border-color);border-bottom:1px solid var(--border-color);margin-bottom:1.5rem}.premium-modal__price{display:flex;align-items:baseline;justify-content:center;gap:.25rem;margin-bottom:.5rem}.premium-modal__price .currency{font-size:1.5rem;color:var(--text-secondary)}.premium-modal__price .amount{font-size:3rem;font-weight:800;color:var(--text-primary)}.premium-modal__price .period{font-size:1.25rem;color:var(--text-secondary)}.premium-modal__trial{font-size:.85rem;color:var(--text-tertiary)}.premium-modal__actions{display:flex;flex-direction:column;gap:.75rem}.premium-modal__actions .btn-premium{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;border:none;padding:1rem 2rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;text-decoration:none;display:block;text-align:center;box-shadow:0 4px 15px #f5576c4d;transition:transform .15s ease,box-shadow .15s ease}.premium-modal__actions .btn-premium:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f5576c66}.premium-modal__actions .btn-premium:active{transform:translateY(0)}.premium-modal__actions .btn-partner{display:block;text-align:center;text-decoration:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);background:linear-gradient(135deg,#d4af371a,#d4af370d);border:1px solid rgba(212,175,55,.3);color:#d4af37;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.premium-modal__actions .btn-partner:hover{background:linear-gradient(135deg,#d4af3726,#d4af371a);border-color:#d4af37}.premium-modal__actions .btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:.95rem;cursor:pointer;transition:background-color .15s ease,border-color .15s ease}.premium-modal__actions .btn-secondary:hover{background:var(--bg-secondary);border-color:var(--text-tertiary)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:576px){.premium-modal{padding:1.5rem}.premium-modal__crown{font-size:3rem}.premium-modal h2{font-size:1.5rem}.premium-modal__price .amount{font-size:2.5rem}}.sidebar-backdrop{display:none}@media(max-width:768px){.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000080;z-index:59;animation:fadeIn .2s ease}}.sidebar{position:fixed;top:var(--navbar-height);left:0;width:var(--sidebar-width);height:calc(100vh - var(--navbar-height));background:var(--card-bg);border-right:1px solid var(--border-color);padding:1.5rem 0;overflow-y:auto;overflow-x:hidden;z-index:60;transition:width .3s ease,transform .3s ease}.sidebar--collapsed{width:var(--sidebar-collapsed-width)}.sidebar--collapsed .sidebar__nav{align-items:center}.sidebar--collapsed .sidebar__link{justify-content:center;padding:.875rem .5rem}.sidebar__toggle{position:fixed;bottom:2rem;left:var(--sidebar-width);background:var(--card-bg);border:1px solid var(--border-color);border-left:none;border-radius:0 var(--radius-md) var(--radius-md) 0;width:22px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.6rem;color:var(--text-secondary);transition:all .3s ease;z-index:61}.sidebar__toggle--collapsed{left:var(--sidebar-collapsed-width)}.sidebar__toggle:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}.sidebar__nav{display:flex;flex-direction:column;gap:.25rem;padding:0 1rem}.sidebar__link{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);font-weight:500;transition:all .2s ease;position:relative;white-space:nowrap}.sidebar__link:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar__link--active{background:var(--primary-light);color:var(--primary);font-weight:600}.sidebar__link--active:hover{background:var(--primary-light)}.sidebar__link--disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.sidebar__link--disabled:hover{background:transparent}.sidebar__link--locked{cursor:pointer}.sidebar__link--locked:hover{background:linear-gradient(135deg,#ffecd2,#fcb69f);color:var(--text-primary)}.sidebar__icon{font-size:1.25rem;flex-shrink:0}.sidebar__badge{margin-left:auto;padding:.15rem .5rem;background:linear-gradient(135deg,#ffd89b,#19547b);color:#fff;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;border-radius:3px;box-shadow:0 2px 8px #0000004d;white-space:nowrap;flex-shrink:0}.sidebar__badge--premium{background:linear-gradient(135deg,#f093fb,#f5576c);animation:pulse-premium 2s ease-in-out infinite}@keyframes pulse-premium{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:768px){.sidebar{transform:translate(-100%);width:var(--sidebar-width);height:calc(100vh - var(--navbar-height));height:calc(100dvh - var(--navbar-height));box-shadow:none}.sidebar.sidebar--open{transform:translate(0);box-shadow:4px 0 20px #00000026}.sidebar .sidebar__toggle{display:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.layout{min-height:100vh;background:var(--bg-primary)}.layout__container{display:flex;padding-top:var(--navbar-height)}.layout__main{flex:1;margin-left:var(--sidebar-width);transition:margin-left .3s ease;overflow-x:hidden;max-width:100%}.layout__main--expanded{margin-left:var(--sidebar-collapsed-width)}@media(max-width:768px){.layout__main{margin-left:0;padding:.75rem}}.dashboard{max-width:100%;overflow-x:hidden}.dashboard__header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1.5rem 2rem}@media(max-width:768px){.dashboard__header{flex-direction:column;padding:1rem}}.dashboard__header-left{flex:1;min-width:0}.dashboard__title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}@media(max-width:768px){.dashboard__title{font-size:1.5rem}}@media(max-width:480px){.dashboard__title{font-size:1.25rem}}.dashboard__subtitle{color:var(--text-secondary);margin:0;font-size:.95rem}@media(max-width:768px){.dashboard__subtitle{font-size:.85rem}}.dashboard__zone{color:var(--primary);font-weight:500}.dashboard__garden-selector{display:inline-flex;align-items:center;gap:.5rem;background:var(--card-bg, #fff);border:1.5px solid var(--border-color, #e5e7eb);border-radius:var(--radius-lg, .75rem);padding:.4rem .75rem;transition:border-color var(--transition-base, .2s),box-shadow var(--transition-base, .2s)}.dashboard__garden-selector:focus-within{border-color:var(--primary, #22c55e);box-shadow:0 0 0 3px #22c55e1a}.dashboard__garden-selector label{font-size:.85rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.dashboard__garden-selector select{border:none;background:transparent;font-size:.9rem;font-weight:600;color:var(--primary, #22c55e);cursor:pointer;font-family:inherit}.dashboard__garden-selector select:focus{outline:none}@media(max-width:768px){.dashboard__garden-selector{width:100%}.dashboard__garden-selector select{flex:1}}.dashboard__weather-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;padding:0 2rem;margin-bottom:1.5rem}@media(min-width:769px)and (max-width:1024px){.dashboard__weather-row{padding:0 1.5rem;gap:1rem}}@media(max-width:768px){.dashboard__weather-row{grid-template-columns:repeat(3,1fr);padding:0 1rem;gap:.5rem}}@media(max-width:480px){.dashboard__weather-row{padding:0 .5rem;gap:.4rem}}.dashboard__stats-row{padding:0 2rem;margin-bottom:1.5rem}@media(min-width:769px)and (max-width:1024px){.dashboard__stats-row{padding:0 1.5rem}}@media(max-width:768px){.dashboard__stats-row{padding:0 1rem}}@media(max-width:480px){.dashboard__stats-row{padding:0 .5rem}}.dashboard__bottom-row{display:grid;grid-template-columns:2fr 1fr;gap:1.5rem;padding:0 2rem;margin-bottom:2rem}@media(min-width:769px)and (max-width:1024px){.dashboard__bottom-row{padding:0 1.5rem;gap:1rem}}@media(max-width:768px){.dashboard__bottom-row{grid-template-columns:1fr;padding:0 1rem;gap:1rem}}@media(max-width:480px){.dashboard__bottom-row{padding:0 .5rem;gap:.75rem}}.dashboard__weather-row-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;padding:0 2rem;margin-bottom:1.5rem}@media(min-width:769px)and (max-width:1024px){.dashboard__weather-row-2{padding:0 1.5rem;gap:1rem}}@media(max-width:768px){.dashboard__weather-row-2{padding:0 1rem;gap:.5rem}}@media(max-width:480px){.dashboard__weather-row-2{padding:0 .5rem;gap:.4rem}}.dashboard__forecast-row{padding:0 2rem;margin-bottom:1.5rem}@media(min-width:769px)and (max-width:1024px){.dashboard__forecast-row{padding:0 1.5rem}}@media(max-width:768px){.dashboard__forecast-row{padding:0 1rem}}@media(max-width:480px){.dashboard__forecast-row{padding:0 .5rem}}.weather-card{display:flex;align-items:center;gap:1rem;padding:1.25rem 1.5rem;position:relative}@media(max-width:768px){.weather-card{flex-direction:column;align-items:flex-start;padding:.75rem;gap:.4rem}}.weather-card__icon{font-size:2.5rem;line-height:1;flex-shrink:0}@media(max-width:768px){.weather-card__icon{font-size:1.5rem}}.weather-card__body{flex:1;min-width:0}.weather-card__value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1.1}@media(max-width:768px){.weather-card__value{font-size:1.15rem}}.weather-card__label{font-size:.85rem;color:var(--text-secondary);text-transform:capitalize;margin-top:.2rem}@media(max-width:768px){.weather-card__label{font-size:.7rem}}.weather-card__range{display:flex;gap:.75rem;margin-top:.5rem;font-size:.85rem;font-weight:600}@media(max-width:768px){.weather-card__range{gap:.4rem;font-size:.7rem;margin-top:.25rem}}.weather-card__min{color:#5c97cf}.weather-card__max{color:#e57a2f}.weather-card__city{position:absolute;top:.75rem;right:1rem;font-size:.75rem;color:var(--text-secondary);font-weight:500}@media(max-width:768px){.weather-card__city{position:static;font-size:.65rem}}.weather-card__bar{height:6px;background:var(--bg-tertiary, #e0e0e0);border-radius:3px;margin-top:.5rem;overflow:hidden}@media(max-width:768px){.weather-card__bar{margin-top:.25rem;height:4px}}.weather-card__bar-fill{height:100%;background:linear-gradient(90deg,#64b5f6,#1976d2);border-radius:3px;transition:width .6s ease}.weather-card--temp{border-left:4px solid #e57a2f}@media(max-width:768px){.weather-card--temp{border-left-width:3px}}.weather-card--humidity{border-left:4px solid #1976d2}@media(max-width:768px){.weather-card--humidity{border-left-width:3px}}.weather-card--sun{border-left:4px solid #ffa726}@media(max-width:768px){.weather-card--sun{border-left-width:3px}}.weather-card--rain{border-left:4px solid #42a5f5}@media(max-width:768px){.weather-card--rain{border-left-width:3px}}.weather-card--pressure{border-left:4px solid #ab47bc}@media(max-width:768px){.weather-card--pressure{border-left-width:3px}}.weather-card__detail{font-size:.75rem;color:var(--text-secondary);margin-top:.2rem;opacity:.85}@media(max-width:768px){.weather-card__detail{font-size:.6rem}}.weather-card__risk{font-size:.7rem;font-weight:600;margin-top:.35rem;padding:2px 8px;border-radius:10px;display:inline-block}.weather-card__risk--high{background:#ffebee;color:#c62828}.weather-card__risk--medium{background:#fff3e0;color:#e65100}@media(max-width:768px){.weather-card__risk{font-size:.6rem;padding:1px 6px}}.weather-card__separator{width:1px;align-self:stretch;background:var(--border-color, #e0e0e0);flex-shrink:0}@media(max-width:768px){.weather-card__separator{display:none}}.forecast-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem}@media(max-width:768px){.forecast-grid{gap:.5rem}}@media(max-width:480px){.forecast-grid{gap:.3rem}}.forecast-day{text-align:center;padding:1rem .5rem;background:var(--bg-secondary);border-radius:var(--radius-md);transition:all .2s ease}.forecast-day:hover{background:var(--bg-tertiary);transform:translateY(-2px)}.forecast-day__name{font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}@media(max-width:768px){.forecast-day__name{font-size:.7rem;margin-bottom:.25rem}}.forecast-day__icon{font-size:1.75rem;margin-bottom:.5rem}@media(max-width:768px){.forecast-day__icon{font-size:1.25rem;margin-bottom:.25rem}}.forecast-day__temps{display:flex;justify-content:center;gap:.5rem;font-size:.9rem;font-weight:600}@media(max-width:768px){.forecast-day__temps{font-size:.75rem;gap:.25rem}}.forecast-day__max{color:#e57a2f}.forecast-day__min{color:#5c97cf}.forecast-day__rain{font-size:.7rem;color:#1976d2;margin-top:.35rem}@media(max-width:768px){.forecast-day__rain{font-size:.6rem}}.actions-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.actions-list__empty{color:var(--text-secondary);font-style:italic;text-align:center;padding:1rem;font-size:.9rem}.actions-list__more{text-align:center;font-size:.85rem;color:var(--text-secondary);margin:.5rem 0}.action-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--border-color);transition:all .2s ease}.action-item:hover{background:var(--bg-tertiary);transform:translate(4px)}.action-item--high{border-left-color:var(--danger)}.action-item--medium{border-left-color:var(--warning)}.action-item--low{border-left-color:var(--success)}.action-item__icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--card-bg);border-radius:var(--radius-md);color:var(--primary)}.action-item__content{flex:1}.action-item__plant{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.action-item__type{font-size:.875rem;color:var(--text-secondary);text-transform:capitalize}.action-item__date{font-size:.875rem;color:var(--text-secondary);white-space:nowrap}.alerts-list{display:flex;flex-direction:column;gap:.75rem}.alert{display:flex;gap:1rem;padding:1rem;border-radius:var(--radius-md);border:1px solid}.alert--warning{background:var(--warning-light);border-color:var(--warning);color:var(--warning-dark)}.alert--warning svg{color:var(--warning)}.alert--info{background:var(--info-light);border-color:var(--info);color:var(--info-dark)}.alert--info svg{color:var(--info)}.alert--success{background:#e8f5e9;border-color:#4caf50;color:#2e7d32}.alert__title{font-weight:600;margin-bottom:.25rem}.alert__text{font-size:.875rem;opacity:.9}.stats-grid>*{flex:1;min-width:0}@media(max-width:768px){.stats-grid{flex-wrap:wrap;gap:.75rem}.stats-grid>*{flex:1 1 calc(33.333% - .5rem);min-width:80px}}@media(max-width:480px){.stats-grid>*{flex:1 1 calc(50% - .5rem)}}.stat-card{padding:1.25rem;background:var(--bg-secondary);border-radius:var(--radius-lg);text-align:center;transition:all .2s ease}.stat-card:hover{background:var(--bg-tertiary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card__icon{font-size:1.5rem;margin-bottom:.4rem;line-height:1}.stat-card__value{font-size:2rem;font-weight:700;color:var(--primary);line-height:1;margin-bottom:.5rem}@media(max-width:768px){.stat-card__value{font-size:1.5rem}}.stat-card__label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}@media(max-width:768px){.stat-card__label{font-size:.8rem}}.stat-card__trend{font-size:.75rem;color:var(--text-secondary)}.stat-card__trend--warning{color:var(--warning);font-weight:600}.stat-card__trend--up{color:var(--success);font-weight:600}.stat-card__trend--down{color:var(--danger);font-weight:600}.stat-card--accent{background:var(--primary-light, #e8f5e9);border:1px solid var(--primary, #2d6a4f)}.card__subtitle{font-size:.8rem;color:var(--text-secondary);font-weight:500;margin-left:.5rem}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite}.skeleton--weather{height:200px;border-radius:var(--radius-md)}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.v3-editor{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;background:var(--bg-primary, #f9fafb);font-family:system-ui,-apple-system,sans-serif;color:var(--text-primary, #111827)}.v3-header{height:48px;display:flex;align-items:center;gap:6px;padding:0 8px;background:var(--card-bg, #ffffff);border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0;z-index:10}.v3-back{background:none;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:5px 8px;font-size:.82rem;cursor:pointer;color:var(--text-primary, #111827);white-space:nowrap;flex-shrink:0;transition:background .15s}.v3-back:hover{background:var(--bg-secondary)}.v3-readonly-bar{flex:1;display:flex;align-items:center;justify-content:center;gap:12px}.v3-readonly-label{font-weight:600;font-size:15px}.v3-mode-toggle{background:none;border:1px solid var(--border-color, #e5e7eb);border-radius:20px;padding:4px 14px;font-size:.8rem;font-weight:600;cursor:pointer;color:var(--primary-dark, #16a34a);white-space:nowrap;flex-shrink:0;transition:all .15s}.v3-mode-toggle:hover{background:var(--primary-light, #dcfce7);border-color:var(--primary, #22c55e)}.v3-mode-toggle--preview{color:var(--text-secondary, #6b7280);margin-right:4px;flex-shrink:0}.v3-mode-toggle--preview:hover{background:var(--bg-secondary, #f3f4f6);color:var(--text-primary, #111827)}.v3-topbar{background:var(--bg-secondary, #f3f4f6);border-bottom:1px solid var(--border-color, #e5e7eb);flex-shrink:0;z-index:9}.tb-row{display:flex;align-items:center;gap:4px;padding:0 8px}.tb-row.tb-row-tools{min-height:38px}.tb-steps-scroll{display:flex;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tb-steps-scroll::-webkit-scrollbar{display:none}.tb-steps-scroll{flex:1;min-width:0}.tb-step{display:flex;align-items:center;gap:5px;padding:6px 12px;border:none;background:none;border-radius:20px;cursor:pointer;color:var(--text-secondary, #6b7280);font-size:.78rem;font-weight:500;white-space:nowrap;flex-shrink:0;transition:all .15s}.tb-step:hover{background:var(--bg-secondary, #f3f4f6);color:var(--text-primary, #111827)}.tb-step.active{background:var(--primary-light, #dcfce7);color:var(--primary-dark, #16a34a);font-weight:700}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tb-step{padding:5px 10px;font-size:.72rem}}.tb-step-icon{font-size:1rem}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tb-step-label{display:none}}@media(min-width:768px)and (max-width:1023px)and (min-height:500px){.tb-step-label{display:inline}}.tb-global-actions{display:flex;align-items:center;gap:2px;flex-shrink:0;margin-left:auto}.tb-icon-btn{width:34px;height:32px;border:none;background:none;border-radius:6px;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;color:var(--text-primary, #111827);transition:all .15s}.tb-icon-btn:hover{background:var(--bg-secondary, #f3f4f6)}.tb-icon-btn.active{background:var(--primary-light, #dcfce7);color:var(--primary-dark, #16a34a)}.tb-icon-btn:disabled{opacity:.3;cursor:default}.tb-icon-btn:disabled:hover{background:none}.tb-icon-btn.danger{color:var(--danger, #ef4444)}.tb-icon-btn.danger:hover{background:#fee2e2}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tb-icon-btn{width:30px;height:28px;font-size:.85rem}}.tb-sep{width:1px;height:22px;background:var(--border-color, #e5e7eb);flex-shrink:0;margin:0 4px}.tb-zoom-label{border:none;background:none;color:var(--text-primary, #111827);font-size:.75rem;font-weight:600;min-width:44px;text-align:center;cursor:pointer;padding:2px 4px;border-radius:4px}.tb-zoom-label:hover{background:var(--bg-secondary, #f3f4f6)}.tb-tools-scroll{display:flex;align-items:center;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tb-tools-scroll::-webkit-scrollbar{display:none}.tb-tools-scroll{flex:1;min-width:0}.tb-tool{display:flex;align-items:center;gap:4px;padding:5px 10px;border:1px solid transparent;background:var(--card-bg, #ffffff);border-radius:6px;cursor:pointer;font-size:.78rem;white-space:nowrap;flex-shrink:0;color:var(--text-primary, #111827);transition:all .15s}.tb-tool:hover{border-color:var(--border-color, #e5e7eb)}.tb-tool.active{background:var(--primary-light, #dcfce7);border-color:var(--primary, #22c55e);color:var(--primary-dark, #16a34a);font-weight:600}.tb-tool.confirm{background:var(--primary, #22c55e);color:#fff;border-color:var(--primary, #22c55e)}.tb-tool.confirm:hover{opacity:.9}.tb-tool.cancel{background:var(--bg-secondary);color:var(--danger, #ef4444)}.tb-tool.cancel:hover{background:#fee2e2}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tb-tool span{display:none}}.tb-poly-info{font-size:.75rem;font-weight:600;color:var(--primary-dark, #16a34a);padding:0 4px;white-space:nowrap}.tb-zone-scroll{display:flex;gap:3px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.tb-zone-scroll::-webkit-scrollbar{display:none}.tb-zone-chip{display:flex;align-items:center;gap:3px;padding:4px 8px;border:1px solid transparent;background:var(--card-bg, #ffffff);border-radius:14px;cursor:pointer;font-size:.7rem;white-space:nowrap;flex-shrink:0;color:var(--text-primary, #111827);transition:all .15s}.tb-zone-chip:hover{border-color:var(--border-color, #e5e7eb);background:var(--bg-secondary)}.tb-zone-chip.active{background:var(--primary-light, #dcfce7);border-color:var(--primary, #22c55e);color:var(--primary-dark, #16a34a);font-weight:600}.tb-hint-inline{font-size:.72rem;color:var(--text-secondary, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 4px}.v3-body{flex:1;display:flex;overflow:hidden;position:relative}.v3-canvas-area{flex:1;position:relative;overflow:hidden;background:#eae4dd}.v3-canvas-area .canvas-container{margin-top:26px;margin-left:26px}.v3-canvas-area canvas{border-radius:2px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-canvas-area .canvas-container{margin-top:20px;margin-left:20px}}.v3-ruler{position:absolute;z-index:5;pointer-events:none}.v3-ruler.v3-ruler-corner{top:0;left:0;background:#1a1a1a;border-right:1px solid #444;border-bottom:1px solid #444}.v3-ruler.v3-ruler-top{top:0;left:26px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-ruler.v3-ruler-top{left:20px}}.v3-ruler.v3-ruler-left{top:26px;left:0}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-ruler.v3-ruler-left{top:20px}}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-ruler.v3-ruler-corner{width:20px!important;height:20px!important}}.v3-right-panel{width:300px;flex-shrink:0;border-left:1px solid var(--border-color, #e5e7eb);background:var(--card-bg, #ffffff);overflow-y:auto;animation:v3SlideIn .2s ease}.v3-right-panel.wide{width:360px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-right-panel{display:none}}@media(min-width:768px)and (max-width:1023px)and (min-height:500px){.v3-right-panel{width:260px}.v3-right-panel.wide{width:300px}}@keyframes v3SlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.v3-palette{display:flex;flex-direction:column;height:100%}.pal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid var(--border-color, #e5e7eb)}.pal-header h3{font-size:.92rem;font-weight:700}.pal-count{font-size:.72rem;color:var(--text-secondary, #6b7280);background:var(--bg-secondary);padding:2px 8px;border-radius:10px}.pal-filters{padding:8px 12px;display:flex;flex-direction:column;gap:6px;border-bottom:1px solid var(--border-color, #e5e7eb)}.pal-search{width:100%;padding:7px 10px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:.82rem;background:var(--bg-primary, #f9fafb);color:var(--text-primary, #111827);outline:none}.pal-search:focus{border-color:var(--primary, #22c55e);box-shadow:0 0 0 2px #22c55e26}.pal-filter-row{display:flex;gap:4px}.pal-filter-row select{flex:1;padding:4px;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.72rem;background:var(--card-bg, #ffffff);color:var(--text-primary, #111827);cursor:pointer}.pal-filter-row select:focus{border-color:var(--primary, #22c55e)}.pal-list{flex:1;overflow-y:auto;padding:6px}.pal-loading,.pal-empty{text-align:center;padding:20px;color:var(--text-secondary, #6b7280);font-size:.82rem}.pal-card{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:1px solid transparent;background:none;border-radius:8px;cursor:pointer;text-align:left;transition:all .15s;position:relative}.pal-card:hover{background:var(--bg-secondary);border-color:var(--border-color, #e5e7eb)}.pal-card.selected{background:var(--primary-light, #dcfce7);border-color:var(--primary, #22c55e)}.pal-card.placed{opacity:.55}.pal-card-icon{font-size:1.3rem;flex-shrink:0}.pal-card-info{flex:1;min-width:0;display:flex;flex-direction:column}.pal-card-name{font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary, #111827)}.pal-card-latin{font-size:.65rem;color:var(--text-secondary, #6b7280);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pal-card-badges{display:flex;gap:2px;font-size:.68rem;flex-shrink:0}.pal-placed-badge{position:absolute;top:3px;right:5px;font-size:.55rem;background:var(--primary, #22c55e);color:#fff;width:15px;height:15px;border-radius:50%;display:flex;align-items:center;justify-content:center}.v3-plant-tooltip{position:fixed;z-index:100;pointer-events:none;background:#000c;color:#fff;font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:6px;white-space:nowrap;box-shadow:0 2px 8px #0003}.v3-float-toggle{position:absolute;top:30px;right:10px;z-index:90;width:44px;height:44px;border-radius:50%;border:2px solid var(--border-color, #e5e7eb);background:var(--card-bg, #ffffff);font-size:1.2rem;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0000002e;opacity:.85;transition:all .2s;-webkit-user-select:none;user-select:none}.v3-float-toggle:hover{opacity:1;transform:scale(1.1)}.v3-float-toggle--edit{border-color:var(--primary, #22c55e)}.v3-float-toggle--edit:hover{background:var(--primary-light, #dcfce7)}.v3-float-toggle--preview{border-color:var(--text-secondary, #6b7280)}.v3-float-toggle--preview:hover{background:var(--bg-secondary, #f3f4f6)}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-float-toggle{bottom:54px;right:14px;width:40px;height:40px;font-size:1.1rem}}.compass-widget{position:absolute;top:25px;left:30px;z-index:90;display:flex;flex-direction:column;align-items:center;user-select:none;-webkit-user-select:none;opacity:.85;transition:opacity .2s}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.compass-widget{bottom:50px}}.compass-widget:hover,.compass-widget--dragging{opacity:1}.compass-widget--readonly{cursor:default}.compass-widget svg{filter:drop-shadow(0 2px 6px rgba(0,0,0,.35))}.compass-widget__deg{margin-top:2px;font-size:.6rem;font-weight:700;color:#ffffffd9;background:#0f172ab3;padding:1px 6px;border-radius:4px;letter-spacing:.5px}.v3-properties{position:absolute;top:12px;right:12px;width:min(380px,100vw - 24px);max-height:calc(100vh - 80px);display:flex;flex-direction:column;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;box-shadow:0 8px 30px #0000001f;z-index:20;animation:v3FadeIn .15s ease;overflow:hidden}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-properties{position:static;width:100%;max-height:70vh;border-radius:0;box-shadow:none;border:none;border-top:1px solid var(--border-color, #e5e7eb)}}@keyframes v3FadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.prop-header{display:flex;align-items:center;gap:6px;padding:8px 12px;flex-shrink:0;background:var(--primary, #22c55e);color:#fff}.prop-header h3{font-size:.85rem;font-weight:700;flex:1}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-header{padding:5px 10px}.prop-header h3{font-size:.78rem}}.prop-draggable{cursor:grab;-webkit-user-select:none;user-select:none}.prop-draggable:active{cursor:grabbing}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-draggable{cursor:default}}.prop-drag-handle{font-size:1rem;opacity:.6;letter-spacing:-2px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-drag-handle{display:none}}.prop-close{background:#fff3;border:none;color:#fff;width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.prop-close:hover{background:#ffffff59}.prop-body{padding:10px 12px;overflow-y:auto;flex:1;min-height:0}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-body{padding:6px 8px}}.prop-plant-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.prop-plant-header .prop-icon{font-size:1.8rem}.prop-plant-header strong{display:block;font-size:.85rem}.prop-plant-header em{font-size:.7rem;color:var(--text-secondary, #6b7280)}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-plant-header{gap:6px;margin-bottom:6px}.prop-plant-header .prop-icon{font-size:1.3rem}.prop-plant-header strong{font-size:.78rem}.prop-plant-header em{font-size:.62rem}}.prop-grid{display:grid;grid-template-columns:1fr 1fr;gap:5px;margin-bottom:10px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-grid{grid-template-columns:1fr 1fr 1fr;gap:3px;margin-bottom:6px}}.prop-item{background:var(--bg-secondary);padding:5px 7px;border-radius:6px}.prop-item label{display:block;font-size:.6rem;color:var(--text-secondary, #6b7280);text-transform:uppercase}.prop-item span{font-size:.75rem;font-weight:600}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-item{padding:3px 5px}.prop-item label{font-size:.55rem}.prop-item span{font-size:.68rem}}.prop-item--stage{grid-column:1/-1}.prop-stage-select{width:100%;border:1px solid var(--border-color, #e5e7eb);border-radius:4px;padding:3px 5px;font-size:.75rem;font-weight:600;background:var(--card-bg, #fff);color:inherit;cursor:pointer}.prop-stage-select:focus{border-color:var(--primary, #22c55e);box-shadow:0 0 0 2px #22c55e33}.prop-input{width:100%;border:1px solid var(--border-color, #e5e7eb);border-radius:4px;padding:3px 5px;font-size:.75rem;font-weight:600;background:var(--card-bg, #fff);color:inherit;outline:none;-moz-appearance:textfield}.prop-input::-webkit-inner-spin-button,.prop-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.prop-input:focus{border-color:var(--primary, #22c55e);box-shadow:0 0 0 2px #22c55e33}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-input{font-size:.68rem;padding:2px 4px}}.prop-section{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color, #e5e7eb)}.prop-section-title{font-size:.75rem;font-weight:700;margin-bottom:6px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-section-title{font-size:.7rem;margin-bottom:4px}}.prop-hint{font-size:.65rem;color:var(--text-secondary, #6b7280);margin-top:4px;line-height:1.3}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-hint{font-size:.6rem}}.prop-assoc{margin-bottom:8px}.prop-assoc h4{font-size:.75rem;font-weight:700;margin-bottom:5px}.prop-tags{display:flex;flex-wrap:wrap;gap:3px}.prop-tag{font-size:.68rem;padding:2px 7px;border-radius:10px;font-weight:500}.prop-tag.good{background:#dcfce7;color:#166534}.prop-tag.bad{background:#fee2e2;color:#991b1b}.prop-footer{padding:8px 12px;border-top:1px solid var(--border-color, #e5e7eb);display:flex;gap:8px;flex-shrink:0}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-footer{padding:5px 8px;gap:6px}}.prop-lock{flex:1;padding:7px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:var(--card-bg, #ffffff);color:var(--text-primary, #111827);font-size:.78rem;font-weight:600}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-lock{padding:5px;font-size:.7rem}}.prop-lock{cursor:pointer;transition:all .15s}.prop-lock:hover{background:var(--bg-secondary, #f3f4f6)}.prop-lock.locked{background:#fef3c7;border-color:#f59e0b;color:#92400e}.prop-delete{flex:1;padding:7px;border:none;border-radius:8px;background:var(--danger, #ef4444);color:#fff;font-size:.78rem;font-weight:600}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.prop-delete{padding:5px;font-size:.7rem}}.prop-delete{cursor:pointer}.prop-delete:hover{opacity:.9}.prop-unknown{text-align:center;color:var(--text-secondary, #6b7280);padding:20px 0}.tex-selector{position:relative}.tex-current{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;background:var(--card-bg, #ffffff);color:var(--text-primary, #111827);font-size:.78rem;font-weight:500;cursor:pointer;transition:border-color .15s}.tex-current:hover{border-color:var(--primary, #22c55e)}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tex-current{padding:5px 8px;font-size:.72rem}}.tex-label{flex:1;text-align:left}.tex-arrow{font-size:.6rem;opacity:.6}.tex-thumb-canvas{border-radius:4px;display:block;flex-shrink:0}.tex-dropdown{position:absolute;left:0;right:0;top:100%;margin-top:4px;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;box-shadow:0 8px 24px #0003;z-index:60;max-height:320px;overflow-y:auto;padding:6px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tex-dropdown{max-height:260px}}.tex-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 8px;border:none;border-radius:4px;background:transparent;color:var(--text-primary, #111827);font-size:.75rem;cursor:pointer}.tex-item:hover{background:#ffffff0f}.tex-item.active{background:#22c55e26;color:var(--primary, #22c55e);font-weight:600}.tex-item-icon{font-size:1rem}.tex-category{margin-top:6px}.tex-category:first-of-type{margin-top:2px}.tex-cat-label{font-size:.65rem;font-weight:700;color:var(--text-secondary, #6b7280);padding:4px 6px 2px;text-transform:uppercase;letter-spacing:.04em}.tex-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:2px}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tex-grid{grid-template-columns:repeat(2,1fr)}}.tex-thumb-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 4px;border:2px solid transparent;border-radius:6px;background:transparent;cursor:pointer;transition:all .15s;color:var(--text-primary, #111827)}.tex-thumb-btn:hover{background:#ffffff0f;border-color:#ffffff1a}.tex-thumb-btn.active{border-color:var(--primary, #22c55e);background:#22c55e1a}.tex-thumb-label{font-size:.6rem;font-weight:500;line-height:1.2;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.v3-summary{padding:14px}.v3-summary h3{font-size:.95rem;font-weight:700;margin-bottom:12px}.sum-score-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border-radius:12px;margin-bottom:14px}.sum-score-card span{font-size:.82rem;color:var(--text-secondary, #6b7280)}.sum-score{font-size:1.8rem;font-weight:800;line-height:1}.sum-score.good{color:#16a34a}.sum-score.warn{color:#d97706}.sum-score.bad{color:#dc2626}.sum-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:14px}.sum-stat{background:var(--bg-secondary);border-radius:8px;padding:8px;text-align:center}.sum-stat-value{display:block;font-size:1.2rem;font-weight:800;color:var(--primary-dark, #16a34a)}.sum-stat-label{font-size:.65rem;color:var(--text-secondary, #6b7280)}.sum-section{margin-bottom:14px}.sum-section h4{font-size:.82rem;font-weight:700;margin-bottom:6px}.sum-assoc-list{list-style:none;display:flex;flex-direction:column;gap:3px}.sum-assoc{font-size:.75rem;padding:4px 8px;border-radius:6px}.sum-assoc.good{background:#dcfce7;color:#166534}.sum-assoc.bad{background:#fee2e2;color:#991b1b}.sum-assoc-dist{font-size:.65rem;opacity:.7;font-style:italic}.sum-yield-table{width:100%;border-collapse:collapse;font-size:.75rem}.sum-yield-table th,.sum-yield-table td{text-align:left;padding:4px 6px;border-bottom:1px solid var(--border-color, #e5e7eb)}.sum-yield-table th{font-weight:700;color:var(--text-secondary, #6b7280);font-size:.68rem;text-transform:uppercase}.sum-yield-table tfoot td{border-top:2px solid var(--border-color, #e5e7eb);border-bottom:none}.sum-families{display:flex;flex-wrap:wrap;gap:4px}.sum-family-tag{font-size:.7rem;padding:3px 8px;border-radius:10px;background:var(--info-light, #dbeafe);color:var(--info-dark, #1d4ed8)}.sum-rotation-hint{font-size:.7rem;color:var(--text-secondary, #6b7280);margin-top:6px;line-height:1.4}.sum-sun-info{display:flex;gap:1rem;font-size:.75rem;color:var(--text-secondary, #6b7280);margin-bottom:8px}.sum-sun-info span{white-space:nowrap}.sum-exposure-warnings{display:flex;flex-direction:column;gap:6px}.sum-exposure-item{display:flex;gap:8px;padding:6px 8px;border-radius:8px;font-size:.75rem}.sum-exposure-item.bad{background:#ef444414}.sum-exposure-item.warning{background:#f59e0b14}.sum-exposure-item .sum-exp-icon{font-size:1rem;flex-shrink:0}.sum-exposure-item .sum-exp-body{display:flex;flex-direction:column;gap:2px}.sum-exposure-item .sum-exp-body strong{font-size:.78rem}.sum-exp-tags{display:flex;flex-wrap:wrap;gap:4px}.sum-exp-tag{display:inline-block;padding:1px 6px;border-radius:4px;font-size:.65rem;font-weight:600}.sum-exp-tag.pref-full{background:#facc1533;color:#92400e}.sum-exp-tag.pref-partial{background:#fb923c33;color:#9a3412}.sum-exp-tag.pref-shade{background:#6366f126;color:#3730a3}.sum-exp-tag.zone-full{background:#facc1526;color:#78350f}.sum-exp-tag.zone-partial{background:#fb923c26;color:#7c2d12}.sum-exp-tag.zone-shade{background:#6366f11f;color:#312e81}.sum-exp-suggestion{font-size:.7rem;color:var(--text-secondary, #6b7280);margin:2px 0 0;line-height:1.3}.sum-exp-ok-count{font-size:.75rem;margin-top:6px;color:var(--text-secondary, #6b7280)}.sum-empty{text-align:center;padding:30px 20px;color:var(--text-secondary, #6b7280);font-size:.82rem}.sum-weather-current{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:8px;font-size:.75rem;color:var(--text-secondary, #6b7280)}.sum-weather-temp{font-size:1.4rem;font-weight:800;color:var(--text-primary, #111827)}.sum-weather-desc{text-transform:capitalize}.sum-weather-risks{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.sum-risk-badge{display:inline-flex;align-items:center;gap:2px;padding:2px 8px;border-radius:8px;font-size:.68rem;font-weight:600}.sum-risk-badge.high{background:#fee2e2;color:#991b1b}.sum-risk-badge.medium{background:#fef3c7;color:#92400e}.sum-risk-badge.low{background:#dcfce7;color:#166534}.sum-risk-badge.info{background:#dbeafe;color:#1e40af}.sum-forecast-alerts{display:flex;flex-direction:column;gap:4px;margin-bottom:6px}.sum-forecast-alert{padding:4px 8px;border-radius:6px;font-size:.72rem;line-height:1.3}.sum-forecast-alert strong{display:block;font-size:.74rem}.sum-forecast-alert span{color:var(--text-secondary, #6b7280)}.sum-forecast-alert.frost{background:#ede9fe;color:#5b21b6}.sum-forecast-alert.heat{background:#fef3c7;color:#92400e}.sum-forecast-alert.rain{background:#dbeafe;color:#1e40af}.sum-forecast-alert.wind{background:#f5f5f4;color:#44403c}.sum-forecast-alert.warning{background:#fef3c7;color:#92400e}.sum-forecast-alert.info{background:#ecfdf5;color:#065f46}.sum-forecast-alert.success{background:#dcfce7;color:#166534}.sum-advice-list{display:flex;flex-direction:column;gap:4px}.sum-advice{padding:5px 8px;border-radius:6px;font-size:.72rem;line-height:1.3}.sum-advice strong{display:block;font-size:.74rem}.sum-advice p{margin:2px 0 0;color:var(--text-secondary, #6b7280)}.sum-advice.warning{background:#fef3c7;color:#92400e}.sum-advice.info{background:#dbeafe;color:#1e40af}.sum-advice.success{background:#dcfce7;color:#166534}.sum-ph-info{font-size:.75rem;color:var(--text-secondary, #6b7280);margin-bottom:6px}.sum-ph-alerts{display:flex;flex-direction:column;gap:3px}.sum-ph-alert{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;border-radius:6px;font-size:.72rem}.sum-ph-alert.acid{background:#fef3c7;color:#92400e}.sum-ph-alert.alkaline{background:#ede9fe;color:#5b21b6}.sum-ph-range{font-size:.65rem;opacity:.8;font-weight:600}.sum-harvest-month{margin-bottom:8px}.sum-harvest-month-label{display:block;font-size:.72rem;font-weight:700;text-transform:capitalize;color:var(--primary-dark, #16a34a);margin-bottom:3px;padding-bottom:2px;border-bottom:1px solid var(--border-color, #e5e7eb)}.sum-harvest-items{display:flex;flex-direction:column;gap:2px}.sum-harvest-item{display:flex;justify-content:space-between;align-items:center;padding:3px 8px;font-size:.72rem;border-radius:4px;background:var(--bg-secondary)}.sum-harvest-date{font-size:.65rem;color:var(--text-secondary, #6b7280);white-space:nowrap}.sum-suggestions{display:flex;flex-direction:column;gap:3px}.sum-suggestion{display:flex;flex-direction:column;gap:1px;padding:4px 8px;border-radius:6px;background:#ecfdf5;font-size:.72rem}.sum-sug-pair{color:#065f46}.sum-sug-arrow{opacity:.5;margin:0 2px}.sum-sug-reason{font-size:.62rem;color:var(--text-secondary, #6b7280);font-style:italic}.snap-panel{padding:14px}.snap-panel h4{font-size:.88rem;font-weight:700;margin-bottom:8px}.snap-current{font-size:.75rem;color:var(--text-secondary, #6b7280);margin-bottom:8px}.snap-save-row{display:flex;gap:6px;margin-bottom:12px}.snap-label-input{flex:1;padding:6px 10px;border:1px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:.75rem;background:var(--card-bg, #ffffff);color:var(--text-primary, #111827);outline:none}.snap-label-input:focus{border-color:var(--primary, #22c55e)}.snap-save-btn{padding:6px 12px;border:none;border-radius:8px;background:var(--primary, #22c55e);color:#fff;font-size:.72rem;font-weight:700;cursor:pointer;white-space:nowrap}.snap-save-btn:hover{filter:brightness(1.1)}.snap-list{display:flex;flex-direction:column;gap:4px}.snap-entry{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;border-radius:8px;background:var(--bg-secondary)}.snap-entry-info{display:flex;align-items:center;gap:8px;min-width:0}.snap-entry-icon{font-size:1.1rem;flex-shrink:0}.snap-entry-text{display:flex;flex-direction:column;min-width:0}.snap-entry-text strong{font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.snap-entry-meta{font-size:.62rem;color:var(--text-secondary, #6b7280)}.snap-entry-actions{display:flex;gap:4px;flex-shrink:0}.snap-action{width:26px;height:26px;border:none;border-radius:6px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center}.snap-action.restore{background:#dbeafe;color:#1e40af}.snap-action.restore:hover{background:#bfdbfe}.snap-action.delete{background:#fee2e2;color:#991b1b}.snap-action.delete:hover{background:#fecaca}.snap-loading{font-size:.75rem;color:var(--text-secondary, #6b7280);text-align:center}.snap-empty{font-size:.75rem;color:var(--text-secondary, #6b7280);text-align:center;padding:20px 0}.snbr{position:absolute;top:30px;left:50%;transform:translate(-50%);z-index:90;display:flex;align-items:center;gap:8px;background:#0f172ae0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:6px 10px;max-width:90%;box-shadow:0 4px 16px #0000004d}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.snbr{bottom:10px;max-width:95%;padding:5px 8px}}.snbr-label{font-size:.65rem;font-weight:700;color:#ffffff80;white-space:nowrap;flex-shrink:0;writing-mode:vertical-lr;text-orientation:mixed;letter-spacing:.5px}.snbr-track{display:flex;gap:4px;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}.snbr-track::-webkit-scrollbar{display:none}.snbr-item{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:72px;padding:6px 8px;border:2px solid transparent;border-radius:10px;background:#ffffff0f;cursor:pointer;scroll-snap-align:center;transition:all .15s;flex-shrink:0}.snbr-item:hover{background:#ffffff1f;border-color:#ffffff26}.snbr-item.active{background:#22c55e26;border-color:#22c55e99;box-shadow:0 0 8px #22c55e40}.snbr-item--current.active{background:#3b82f626;border-color:#3b82f699;box-shadow:0 0 8px #3b82f640}.snbr-item-icon{font-size:1.1rem;line-height:1}.snbr-item-label{font-size:.62rem;font-weight:700;color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px;text-align:center}.snbr-item-meta{font-size:.52rem;color:#fff6;white-space:nowrap}.v3-mobile-sheet{display:none}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-mobile-sheet{display:block;position:fixed;bottom:0;left:0;right:0;max-height:30vh;background:var(--card-bg, #ffffff);border-top:1px solid var(--border-color, #e5e7eb);border-radius:12px 12px 0 0;box-shadow:0 -4px 20px #0000001a;overflow-y:auto;z-index:15;animation:v3SheetUp .25s ease}.v3-mobile-sheet.tall{max-height:42vh}}@keyframes v3SheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.v3-modal-overlay{position:fixed;inset:0;z-index:2000;background:#00000073;display:flex;align-items:center;justify-content:center;animation:v3OverlayIn .15s ease;padding:20px}@keyframes v3OverlayIn{0%{opacity:0}to{opacity:1}}.v3-modal{background:var(--card-bg, #ffffff);border-radius:16px;padding:28px 24px 20px;max-width:380px;width:100%;text-align:center;box-shadow:0 12px 40px #0000002e;animation:v3ModalIn .2s ease}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-modal{max-width:340px;padding:24px 20px 16px}}@keyframes v3ModalIn{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.v3-modal-icon{font-size:2.4rem;margin-bottom:8px}.v3-modal-title{font-size:1.05rem;font-weight:700;margin-bottom:6px;color:var(--text-primary, #111827)}.v3-modal-msg{font-size:.82rem;color:var(--text-secondary, #6b7280);line-height:1.5;margin-bottom:20px}.v3-modal-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.v3-modal-btn{padding:9px 20px;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.v3-modal-btn.cancel{background:var(--bg-secondary, #f3f4f6);color:var(--text-primary, #111827)}.v3-modal-btn.cancel:hover{background:var(--bg-tertiary, #e5e7eb)}.v3-modal-btn.confirm{background:var(--primary, #22c55e);color:#fff}.v3-modal-btn.confirm:hover{opacity:.9}.v3-modal-btn.confirm.danger{background:var(--danger, #ef4444)}.v3-modal-btn.confirm.danger:hover{opacity:.9}.v3-modal-btn.confirm:disabled{opacity:.4;cursor:default}.v3-modal-btn.secondary{background:#fef3c7;color:#92400e}.v3-modal-btn.secondary:hover{background:#fde68a}.v3-dims-modal{max-width:400px}.v3-dims-fields{display:flex;align-items:flex-end;gap:10px;justify-content:center;margin-bottom:12px}.v3-dims-field{flex:1;text-align:left}.v3-dims-field label{display:block;font-size:.7rem;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;margin-bottom:4px}.v3-dims-field input{width:100%;padding:8px 10px;border:1.5px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:1rem;font-weight:600;text-align:center;background:var(--bg-secondary, #f9f7f4);color:var(--text-primary, #111827);transition:border-color .15s}.v3-dims-field input:focus{border-color:var(--primary, #22c55e);box-shadow:0 0 0 2px #22c55e26;outline:none}.v3-dims-x{font-size:1.2rem;font-weight:700;color:var(--text-secondary, #6b7280);padding-bottom:8px}.v3-dims-preview{font-size:.82rem;color:var(--text-secondary, #6b7280);margin-bottom:16px}.v3-dims-preview strong{color:var(--primary, #22c55e);font-size:.95rem}[data-theme=dark] .v3-canvas-area{background:#1a1510}[data-theme=dark] .v3-modal{background:var(--card-bg, #1f2937)}[data-theme=dark] .v3-modal-overlay{background:#0009}[data-theme=dark] .tb-tool,[data-theme=dark] .tb-zone-chip{background:var(--card-bg, #1f2937)}[data-theme=dark] .v3-mobile-steps{background:var(--card-bg, #1f2937);border-color:var(--border-color, #374151)}[data-theme=dark] .draw-tool-btn,[data-theme=dark] .draw-zone-chip{background:var(--bg-secondary, #374151);color:var(--text-primary, #f3f4f6)}[data-theme=dark] .tb-settings-menu{background:var(--card-bg, #1f2937);border-color:var(--border-color, #374151)}[data-theme=dark] .tb-settings-menu button{color:var(--text-primary, #f3f4f6)}[data-theme=dark] .tb-settings-menu button:hover{background:var(--bg-secondary, #374151)}.v3-mobile-header-actions{display:none}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-mobile-header-actions{display:flex;align-items:center;gap:1px;margin-left:auto;overflow-x:visible;overflow-y:visible}}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.tb-steps-scroll,.tb-global-actions{display:none}.v3-header{height:40px;padding:0 4px;gap:2px}.v3-topbar{display:none}.tb-icon-btn{width:32px;height:30px;font-size:.92rem}.tb-zoom-label{font-size:.75rem;min-width:38px}.tb-sep{width:1px;height:18px;background:var(--border-color, #e5e7eb);flex-shrink:0;margin:0 2px}}.tb-settings-wrap{position:relative;display:inline-flex}.tb-settings-backdrop{position:fixed;inset:0;z-index:99}.tb-settings-menu{position:absolute;top:100%;right:0;margin-top:4px;z-index:100;background:var(--card-bg, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;box-shadow:0 8px 24px #00000026;padding:4px;min-width:160px;animation:v3SheetUp .15s ease}.tb-settings-menu button{display:block;width:100%;padding:8px 12px;border:none;background:none;color:var(--text-primary, #111827);font-size:.78rem;font-weight:500;text-align:left;border-radius:6px;cursor:pointer;white-space:nowrap;transition:background .12s}.tb-settings-menu button:hover{background:var(--bg-secondary, #f3f4f6)}.tb-settings-menu button.danger{color:var(--danger, #ef4444)}.tb-settings-menu button.danger:hover{background:#fee2e2}.tb-settings-menu button:disabled{opacity:.4;cursor:default}.v3-mobile-steps{display:none}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-mobile-steps{display:flex;position:fixed;bottom:0;left:0;right:0;height:48px;background:var(--card-bg, #ffffff);border-top:1px solid var(--border-color, #e5e7eb);z-index:50;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0)}}.mobile-step{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--text-secondary, #6b7280);padding:4px 0;position:relative;transition:color .15s}.mobile-step.active{color:var(--primary-dark, #16a34a)}.mobile-step.active:after{content:"";position:absolute;top:0;left:25%;right:25%;height:3px;background:var(--primary, #22c55e);border-radius:0 0 3px 3px}.mobile-step-icon{font-size:1.05rem}.mobile-step-label{font-size:.52rem;font-weight:600;white-space:nowrap}.v3-draw-tools{display:flex;flex-direction:column;padding:0}.draw-header{display:flex;align-items:center;padding:10px 14px;border-bottom:1px solid var(--border-color, #e5e7eb)}.draw-header h3{font-size:.92rem;font-weight:700;margin:0}.draw-shapes{display:flex;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border-color, #e5e7eb);overflow-x:auto;align-items:center}.draw-tool-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 10px;border:1px solid transparent;background:var(--bg-secondary, #f3f4f6);border-radius:8px;cursor:pointer;font-size:.68rem;font-weight:500;color:var(--text-primary, #111827);white-space:nowrap;transition:all .12s;min-width:56px}.draw-tool-btn:hover{border-color:var(--border-color, #e5e7eb)}.draw-tool-btn.active{background:var(--primary-light, #dcfce7);border-color:var(--primary, #22c55e);color:var(--primary-dark, #16a34a);font-weight:700}.draw-tool-btn.confirm{background:var(--primary, #22c55e);color:#fff;font-weight:700;min-width:auto}.draw-tool-btn.cancel{color:var(--danger, #ef4444);min-width:auto;background:none}.draw-tool-icon{font-size:1.1rem}.draw-poly-info{font-size:.68rem;color:var(--text-secondary, #6b7280);font-weight:600;padding:0 4px}.draw-zone-types{display:flex;flex-wrap:wrap;gap:6px;padding:8px 12px 10px;overflow-y:auto}.draw-zone-chip{display:flex;align-items:center;gap:4px;padding:6px 10px;border:1px solid transparent;background:var(--bg-secondary, #f3f4f6);border-radius:20px;cursor:pointer;font-size:.72rem;font-weight:500;color:var(--text-primary, #111827);transition:all .12s}.draw-zone-chip:hover{border-color:var(--border-color, #e5e7eb)}.draw-zone-chip.active{background:var(--primary-light, #dcfce7);border-color:var(--primary, #22c55e);color:var(--primary-dark, #16a34a);font-weight:700}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.v3-mobile-sheet{bottom:48px}}.sun-timeline{position:absolute;bottom:8px;left:50%;transform:translate(-50%);z-index:95;background:#0f172ae0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:12px;padding:8px 14px 10px;min-width:320px;max-width:520px;width:60%;box-shadow:0 4px 16px #0000004d;user-select:none;-webkit-user-select:none}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.sun-timeline{bottom:58px;min-width:240px;width:85%;padding:6px 10px 8px}}.sun-timeline.dragging{cursor:grabbing}.sun-tl-info{display:flex;align-items:center;gap:10px;margin-bottom:6px}.sun-tl-time{font-size:1rem;font-weight:800;color:#facc15;font-variant-numeric:tabular-nums}.sun-tl-period{font-size:.72rem;color:#ffffffb3;font-weight:500}.sun-tl-elev{font-size:.68rem;color:#facc15b3;margin-left:auto;font-weight:600}.sun-tl-bar-wrap{display:flex;align-items:center;gap:8px}.sun-tl-edge{font-size:.6rem;color:#ffffff80;white-space:nowrap;flex-shrink:0}.sun-tl-bar{position:relative;flex:1;height:24px;cursor:pointer;touch-action:none}.sun-tl-track{position:absolute;inset:50% 0 0;height:6px;transform:translateY(-50%);border-radius:3px;background:linear-gradient(90deg,#fb718566,#fb923c80 15%,#facc1599 40% 60%,#fb923c80 85%,#fb718566)}.sun-tl-fill{position:absolute;top:50%;left:0;height:6px;transform:translateY(-50%);border-radius:3px 0 0 3px;background:#facc1559;pointer-events:none}.sun-tl-tick{position:absolute;top:50%;transform:translate(-50%,-50%);width:1px;height:10px;background:#fff3}.sun-tl-tick-label{position:absolute;bottom:-14px;left:50%;transform:translate(-50%);font-size:.5rem;color:#ffffff4d;white-space:nowrap}.sun-tl-cursor{position:absolute;top:50%;transform:translate(-50%,-50%);width:28px;height:28px;border-radius:50%;background:#0f172ae6;border:2.5px solid #facc15;display:flex;align-items:center;justify-content:center;cursor:grab;box-shadow:0 2px 8px #0006;transition:box-shadow .15s}.dragging .sun-tl-cursor{cursor:grabbing;box-shadow:0 4px 16px #facc1566}@media(max-width:767px),(max-height:499px)and (max-width:1023px){.sun-tl-cursor{width:32px;height:32px}}.sun-tl-cursor-icon{font-size:.8rem;line-height:1}.tb-icon-btn--magic{animation:magic-glow 2.5s ease-in-out infinite}@keyframes magic-glow{0%,to{filter:drop-shadow(0 0 0 transparent)}50%{filter:drop-shadow(0 0 6px rgba(168,85,247,.5))}}.v3-autoplan-modal{background:var(--card-bg, #fff);border-radius:16px;width:min(460px,92vw);max-height:85vh;overflow-y:auto;box-shadow:0 12px 40px #00000040;animation:modal-in .2s ease-out}@keyframes modal-in{0%{opacity:0;transform:scale(.92) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.v3-autoplan-header{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border-color, #e5e7eb)}.v3-autoplan-header h3{margin:0;font-size:1.1rem;flex:1}.v3-autoplan-icon{font-size:1.6rem}.v3-autoplan-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--text-secondary, #6b7280);padding:4px 8px;border-radius:6px}.v3-autoplan-close:hover{background:var(--bg-secondary, #f3f4f6)}.v3-autoplan-config,.v3-autoplan-result{padding:16px 20px}.v3-autoplan-desc{color:var(--text-secondary, #6b7280);font-size:.88rem;line-height:1.5;margin:0 0 16px}.v3-autoplan-context{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.v3-autoplan-ctx-item{display:flex;align-items:center;gap:8px;background:var(--bg-secondary, #f9fafb);padding:8px 12px;border-radius:8px;font-size:.85rem}.v3-autoplan-ctx-item.v3-ctx-dim{opacity:.5;font-style:italic}.v3-autoplan-options{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.v3-autoplan-mode-selector{display:flex;gap:10px;margin-bottom:16px}.v3-autoplan-mode-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:2px solid var(--border-color, #e5e7eb);border-radius:12px;cursor:pointer;transition:all .2s;background:var(--surface, #fff);text-align:center}.v3-autoplan-mode-card input[type=radio]{display:none}.v3-autoplan-mode-card.active{border-color:var(--primary, #22c55e);background:#22c55e14;box-shadow:0 0 0 2px #22c55e33}.v3-autoplan-mode-card:hover:not(.active){border-color:var(--primary, #22c55e);opacity:.85}.v3-mode-icon{font-size:1.6rem}.v3-mode-title{font-weight:600;font-size:.9rem}.v3-mode-desc{font-size:.72rem;color:var(--text-secondary, #6b7280);line-height:1.2}.v3-autoplan-badge-perma{display:inline-block;margin-left:8px;padding:2px 8px;background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-radius:10px;font-size:.72rem;font-weight:600}.v3-autoplan-opt{display:flex;align-items:center;gap:10px;font-size:.88rem;cursor:pointer}.v3-autoplan-opt input[type=checkbox]{accent-color:var(--primary, #22c55e);width:18px;height:18px}.v3-autoplan-opt input[type=range]{flex:1;accent-color:var(--primary, #22c55e)}.v3-autoplan-range-val{font-weight:600;min-width:28px;text-align:right;color:var(--primary, #22c55e)}.v3-autoplan-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border-color, #e5e7eb)}.v3-autoplan-generate,.v3-autoplan-apply{background:linear-gradient(135deg,#a855f7,#6366f1)!important;color:#fff!important;font-weight:600}.v3-autoplan-generate:hover,.v3-autoplan-apply:hover{filter:brightness(1.08)}.v3-autoplan-score{display:flex;justify-content:center;margin-bottom:16px}.v3-autoplan-score-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#a855f7,#6366f1);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.v3-autoplan-score-num{font-size:1.5rem;font-weight:700;line-height:1}.v3-autoplan-score-label{font-size:.68rem;opacity:.85;text-transform:uppercase;letter-spacing:.5px}.v3-autoplan-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}.v3-autoplan-stat{text-align:center;background:var(--bg-secondary, #f9fafb);padding:10px 6px;border-radius:10px}.v3-autoplan-stat-val{display:block;font-weight:700;font-size:1.05rem;color:var(--primary, #22c55e)}.v3-autoplan-stat-label{font-size:.72rem;color:var(--text-secondary, #6b7280)}.v3-autoplan-season-badge{text-align:center;padding:6px 14px;background:var(--bg-secondary, #f9fafb);border-radius:20px;font-size:.85rem;font-weight:500;margin-bottom:14px;display:inline-block;width:100%}.v3-autoplan-plant-list{margin-bottom:14px;max-height:200px;overflow-y:auto}.v3-autoplan-plant-list h4{font-size:.85rem;margin:0 0 8px;color:var(--text-secondary, #6b7280)}.v3-autoplan-plant-row{display:flex;align-items:center;padding:5px 0;border-bottom:1px solid var(--border-color, #f0f0f0);font-size:.85rem}.v3-autoplan-plant-name{flex:1}.v3-autoplan-plant-qty{margin-right:10px;color:var(--text-secondary, #6b7280);font-size:.8rem}.v3-autoplan-plant-score{font-weight:600;font-size:.78rem;padding:2px 8px;border-radius:10px}.v3-autoplan-plant-score.high{background:#dcfce7;color:#166534}.v3-autoplan-plant-score.mid{background:#fef9c3;color:#854d0e}.v3-autoplan-plant-score.low{background:#fee2e2;color:#991b1b}.v3-autoplan-error{text-align:center;padding:20px}.v3-autoplan-error span{font-size:2rem;display:block;margin-bottom:10px}.v3-autoplan-error p{color:var(--text-secondary, #6b7280);margin-bottom:16px}[data-theme=dark] .v3-autoplan-modal{background:var(--card-bg, #1f2937)}[data-theme=dark] .v3-autoplan-plant-score.high{background:#064e3b;color:#6ee7b7}[data-theme=dark] .v3-autoplan-plant-score.mid{background:#78350f;color:#fde68a}[data-theme=dark] .v3-autoplan-plant-score.low{background:#7f1d1d;color:#fca5a5}[data-theme=dark] .v3-year-round-tab{background:var(--bg-secondary, #374151)}[data-theme=dark] .v3-year-round-tab.active{background:#6366f140}[data-theme=dark] .v3-timeline-bar-track{background:#374151}.v3-autoplan-mode-selector{flex-wrap:wrap}.v3-year-round-tabs{display:flex;gap:6px;margin-bottom:14px}.v3-year-round-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border:2px solid var(--border-color, #e5e7eb);border-radius:10px;background:var(--bg-secondary, #f9fafb);cursor:pointer;transition:all .2s;font-size:.78rem}.v3-year-round-tab.active{border-color:#6366f1;background:#6366f114;box-shadow:0 0 0 2px #6366f133}.v3-year-round-tab:hover:not(.active){border-color:#6366f1;opacity:.85}.v3-round-tab-icon{font-size:1.2rem}.v3-round-tab-label{font-weight:600;font-size:.7rem;line-height:1.2;text-align:center}.v3-round-tab-count{font-size:.65rem;color:var(--text-secondary, #6b7280);font-weight:500}.v3-year-timeline{margin-bottom:14px;overflow-x:auto}.v3-timeline-months{display:flex;align-items:center;gap:0;margin-bottom:4px}.v3-timeline-months .v3-timeline-zone-label{width:72px;min-width:72px;font-size:.7rem}.v3-timeline-month{flex:1;text-align:center;font-size:.65rem;font-weight:600;color:var(--text-secondary, #6b7280);padding:2px 0}.v3-timeline-zone-row{display:flex;align-items:center;margin-bottom:5px}.v3-timeline-zone-label{width:72px;min-width:72px;font-size:.7rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:6px;color:var(--text-secondary, #6b7280)}.v3-timeline-bar-track{flex:1;height:18px;background:var(--bg-secondary, #f3f4f6);border-radius:4px;position:relative;overflow:hidden}.v3-timeline-bar{position:absolute;top:0;height:100%;border-radius:3px;opacity:.85}.v3-timeline-bar.sow{background:linear-gradient(90deg,#22c55e,#4ade80);top:0;height:8px}.v3-timeline-bar.harvest{background:linear-gradient(90deg,#f59e0b,#fbbf24);top:10px;height:8px}.v3-timeline-bar.round{height:100%;opacity:.7;border-radius:4px}.v3-timeline-legend{display:flex;gap:16px;justify-content:center;margin-top:6px;font-size:.7rem;color:var(--text-secondary, #6b7280)}.v3-timeline-legend-item{display:flex;align-items:center;gap:4px}.v3-timeline-dot{display:inline-block;width:10px;height:6px;border-radius:2px}.v3-timeline-dot.sow{background:#22c55e}.v3-timeline-dot.harvest{background:#f59e0b}.v3-season-nav{position:fixed;top:120px;left:50%;transform:translate(-50%);z-index:1200;pointer-events:auto}.v3-season-nav-inner{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#111827eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;box-shadow:0 8px 32px #00000059;border:1px solid rgba(255,255,255,.08)}.v3-season-nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 14px;border:2px solid transparent;border-radius:12px;background:transparent;color:#ffffffb3;cursor:pointer;transition:all .2s;min-width:64px}.v3-season-nav-btn:hover{background:#ffffff0f;color:#fff}.v3-season-nav-btn.active{color:#fff;font-weight:600}.v3-season-nav-icon{font-size:1.3rem;line-height:1}.v3-season-nav-label{font-size:.68rem;font-weight:500;line-height:1.2;white-space:nowrap}.v3-season-nav-count{font-size:.6rem;opacity:.6}.v3-season-nav-close{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:50%;background:#ffffff14;color:#ffffff80;font-size:1rem;cursor:pointer;margin-left:4px;transition:all .2s}.v3-season-nav-close:hover{background:#ef44444d;color:#fff}.v3-season-toggle-fab{position:fixed;top:130px;left:50%;transform:translate(-50%);z-index:1200;width:44px;height:44px;border:none;border-radius:50%;background:#111827eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 20px #00000059;color:#fff;font-size:1.3rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.08)}.v3-season-toggle-fab:hover{background:#22c55e40;transform:translate(-50%) scale(1.1)}.v3-density-picker{display:flex;gap:10px;margin-bottom:14px}.v3-density-card{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;border:2px solid var(--border-color, #e5e7eb);border-radius:12px;background:var(--bg-secondary, #f9fafb);cursor:pointer;transition:all .2s}.v3-density-card.active{border-color:#22c55e;background:#22c55e14;box-shadow:0 0 0 2px #22c55e33}.v3-density-card:hover:not(.active){border-color:#22c55e;opacity:.85}.v3-density-icon{font-size:1.4rem}.v3-density-label{font-weight:600;font-size:.78rem}.v3-density-desc{font-size:.65rem;color:var(--text-secondary, #6b7280);text-align:center}.v3-plan-stats{display:flex;gap:8px;margin-bottom:12px}.v3-plan-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;background:var(--bg-secondary, #f9fafb);border-radius:10px;border:1px solid var(--border-color, #e5e7eb)}.v3-plan-stat-value{font-size:1.1rem;font-weight:700;color:var(--text-primary, #111827)}.v3-plan-stat-label{font-size:.6rem;color:var(--text-secondary, #6b7280);text-align:center}.v3-round-plant-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;max-height:120px;overflow-y:auto}.v3-round-plant-chip{display:flex;align-items:center;gap:4px;padding:4px 10px;background:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:20px;font-size:.72rem;white-space:nowrap}.v3-context-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.v3-context-badge{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:20px;font-size:.7rem;color:var(--text-primary, #111827)}.garden-preview{width:100%;margin:0 auto}.garden-preview .preview-canvas{background:#f5f0eb;border-radius:12px;overflow:hidden;min-height:200px;max-height:350px;display:flex;align-items:center;justify-content:center;border:2px solid #e5e7eb}.garden-preview .preview-canvas canvas{display:block;width:100%;height:auto;border-radius:10px}.garden-preview .preview-canvas.preview-empty{flex-direction:column;gap:4px;padding:40px 20px;background:linear-gradient(135deg,#f9fafb,#f0f0f0)}.garden-preview .preview-canvas.preview-empty p{margin:0;color:#6b7280;font-size:14px;text-align:center}@media(max-width:768px){.garden-preview .preview-canvas{min-height:160px;max-height:260px;border-radius:8px}}.garden-editor{min-height:calc(100vh - 64px);background:#f5f7fa;max-width:100%;overflow-x:hidden}.garden-editor .garden-detail-header{background:#fff;padding:1.5rem 2rem;border-bottom:1px solid #e5e7eb}@media(max-width:768px){.garden-editor .garden-detail-header{padding:1rem}}.garden-editor .garden-detail-header .btn-back{background:transparent;border:none;color:#6366f1;font-size:14px;font-weight:500;padding:.5rem 0;margin-bottom:1rem;cursor:pointer;transition:all .2s}.garden-editor .garden-detail-header .btn-back:hover{color:#4f46e5;transform:translate(-2px)}.garden-editor .garden-detail-header .header-content{display:flex;justify-content:space-between;align-items:center}.garden-editor .garden-detail-header .header-content .header-title{flex:1}.garden-editor .garden-detail-header .header-content .header-title .header-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.garden-editor .garden-detail-header .header-content .header-title h1{margin:0;font-size:28px;font-weight:700;color:#1f2937}.garden-editor .garden-detail-header .header-content .header-title .header-inline-actions{display:flex;gap:.25rem}.garden-editor .garden-detail-header .header-content .header-title .btn-icon{background:transparent;border:none;font-size:18px;cursor:pointer;padding:.375rem;border-radius:6px;transition:background .2s;line-height:1}.garden-editor .garden-detail-header .header-content .header-title .btn-icon:hover{background:#f3f4f6}.garden-editor .garden-detail-header .header-content .header-title .btn-icon--danger:hover{background:#fee2e2}.garden-editor .garden-detail-header .header-content .header-title .header-badges{display:flex;gap:.5rem;flex-wrap:wrap}.garden-editor .garden-detail-header .header-content .header-title .header-badges .badge{display:inline-flex;align-items:center;gap:.25rem;padding:.375rem .75rem;background:#f3f4f6;border-radius:20px;font-size:13px;font-weight:500;color:#4b5563}.garden-editor .garden-detail-header .header-content .header-title .header-badges .badge.badge-location{background:#dbeafe;color:#1e40af}.garden-editor .garden-detail-header .header-content .header-title .header-badges .badge.badge-area{background:#dcfce7;color:#166534}.garden-editor .garden-detail-header .header-content .header-title .header-badges .badge.badge-plants{background:#fef3c7;color:#92400e}.garden-editor .garden-detail-header .header-content .header-title .header-badges .badge.badge-household{background:#e0e7ff;color:#4338ca}.garden-editor .garden-detail-header .header-content .header-title .header-badges .badge.badge-shared{background:#ede9fe;color:#6d28d9}.garden-editor .garden-tabs{background:#fff;padding:0 2rem;border-bottom:2px solid #e5e7eb;display:flex;gap:1.5rem}.garden-editor .garden-tabs .tab{background:transparent;border:none;border-bottom:3px solid transparent;padding:1rem .5rem;font-size:15px;font-weight:500;color:#6b7280;cursor:pointer;transition:all .2s;position:relative;bottom:-2px}.garden-editor .garden-tabs .tab:hover{color:#374151}.garden-editor .garden-tabs .tab.active{color:#6366f1;border-bottom-color:#6366f1}.garden-editor .garden-content{padding:2rem;max-width:1400px;margin:0 auto}.garden-editor .garden-content .tab-overview{display:flex;flex-direction:column}.garden-editor .garden-content .tab-overview .overview-section{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.garden-editor .garden-content .tab-overview .overview-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.garden-editor .garden-content .tab-overview .overview-section .section-header h2{margin:0;font-size:20px;font-weight:600;color:#1f2937}.garden-editor .garden-content .tab-overview .overview-section .section-header .btn-primary-small{padding:.5rem 1rem;background:#6366f1;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.garden-editor .garden-content .tab-overview .overview-section .section-header .btn-primary-small:hover{background:#4f46e5;transform:translateY(-1px)}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .canvas-preview-container{position:relative}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .canvas-preview-container .canvas-preview{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;min-height:300px;max-height:450px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;padding:0;overflow:hidden}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .canvas-preview-container .canvas-preview .preview-placeholder{color:#9ca3af;font-style:italic}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .canvas-preview-container .btn-edit-canvas{width:100%;padding:.75rem;background:#6366f1;color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .canvas-preview-container .btn-edit-canvas:hover{background:#4f46e5}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .empty-canvas{text-align:center;padding:3rem 1rem}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .empty-canvas .empty-icon{font-size:64px;margin-bottom:1rem;opacity:.5}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .empty-canvas h3{margin:0 0 .5rem;font-size:20px;color:#374151}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .empty-canvas p{margin:0 0 1.5rem;color:#6b7280;font-size:15px}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .empty-canvas .btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.garden-editor .garden-content .tab-overview .overview-section.canvas-preview-section .empty-canvas .btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f159}.garden-editor .garden-content .tab-overview .overview-section.garden-info .info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.garden-editor .garden-content .tab-overview .overview-section.garden-info .info-grid .info-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb;transition:all .2s}.garden-editor .garden-content .tab-overview .overview-section.garden-info .info-grid .info-card:hover{background:#f3f4f6;border-color:#d1d5db}.garden-editor .garden-content .tab-overview .overview-section.garden-info .info-grid .info-card .info-icon{font-size:28px;flex-shrink:0}.garden-editor .garden-content .tab-overview .overview-section.garden-info .info-grid .info-card .info-content{display:flex;flex-direction:column;gap:.25rem}.garden-editor .garden-content .tab-overview .overview-section.garden-info .info-grid .info-card .info-content .info-label{font-size:13px;color:#6b7280;font-weight:500}.garden-editor .garden-content .tab-overview .overview-section.garden-info .info-grid .info-card .info-content .info-value{font-size:16px;color:#1f2937;font-weight:600}.garden-editor .garden-content .tab-overview .overview-section.garden-household .household-link select{width:100%;max-width:400px;padding:.75rem 1rem;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;color:#1f2937;background:#fff;cursor:pointer}.garden-editor .garden-content .tab-overview .overview-section.garden-household .household-link select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.garden-editor .garden-content .tab-overview .overview-section.garden-household .household-link .household-hint{margin:.5rem 0 0;font-size:13px;color:#6b7280}.garden-editor .garden-content .tab-overview .overview-section.garden-household .household-empty{color:#6b7280;font-size:14px;padding:1rem;background:#f9fafb;border-radius:8px;border:1px dashed #d1d5db}.garden-editor .garden-content .tab-overview .overview-section.quick-actions .actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.garden-editor .garden-content .tab-overview .overview-section.quick-actions .actions-grid .action-card{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem 1rem;background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s}.garden-editor .garden-content .tab-overview .overview-section.quick-actions .actions-grid .action-card:hover{background:#fff;border-color:#6366f1;transform:translateY(-2px);box-shadow:0 4px 12px #6366f126}.garden-editor .garden-content .tab-overview .overview-section.quick-actions .actions-grid .action-card:hover .action-icon{transform:scale(1.1)}.garden-editor .garden-content .tab-overview .overview-section.quick-actions .actions-grid .action-card .action-icon{font-size:32px;transition:transform .2s}.garden-editor .garden-content .tab-overview .overview-section.quick-actions .actions-grid .action-card .action-label{font-size:14px;font-weight:500;color:#4b5563;text-align:center}.garden-editor .garden-content .tab-potager,.garden-editor .garden-content .tab-calendar,.garden-editor .garden-content .tab-weather,.garden-editor .garden-content .tab-stats{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 1px 3px #0000001a;min-height:400px}@media(max-width:768px){.garden-editor .garden-content .tab-potager,.garden-editor .garden-content .tab-calendar,.garden-editor .garden-content .tab-weather,.garden-editor .garden-content .tab-stats{padding:1rem}}.garden-editor .garden-content .tab-potager h2,.garden-editor .garden-content .tab-calendar h2,.garden-editor .garden-content .tab-weather h2,.garden-editor .garden-content .tab-stats h2{margin:0 0 1rem;font-size:20px;font-weight:600;color:#1f2937}.garden-editor .garden-content .tab-potager h3,.garden-editor .garden-content .tab-calendar h3,.garden-editor .garden-content .tab-weather h3,.garden-editor .garden-content .tab-stats h3{margin:1.5rem 0 .75rem;font-size:17px;font-weight:600;color:#374151}.garden-editor .garden-content .tab-potager .tab-placeholder,.garden-editor .garden-content .tab-calendar .tab-placeholder,.garden-editor .garden-content .tab-weather .tab-placeholder,.garden-editor .garden-content .tab-stats .tab-placeholder{color:#9ca3af;font-style:italic}.garden-editor .garden-content .tab-potager .canvas-fullview .empty-canvas,.garden-editor .garden-content .tab-calendar .canvas-fullview .empty-canvas,.garden-editor .garden-content .tab-weather .canvas-fullview .empty-canvas,.garden-editor .garden-content .tab-stats .canvas-fullview .empty-canvas{text-align:center;padding:4rem 2rem}.garden-editor .garden-content .tab-potager .canvas-fullview .empty-canvas .empty-icon,.garden-editor .garden-content .tab-calendar .canvas-fullview .empty-canvas .empty-icon,.garden-editor .garden-content .tab-weather .canvas-fullview .empty-canvas .empty-icon,.garden-editor .garden-content .tab-stats .canvas-fullview .empty-canvas .empty-icon{font-size:72px;margin-bottom:1.5rem;opacity:.4}.garden-editor .garden-content .tab-potager .canvas-fullview .empty-canvas h3,.garden-editor .garden-content .tab-calendar .canvas-fullview .empty-canvas h3,.garden-editor .garden-content .tab-weather .canvas-fullview .empty-canvas h3,.garden-editor .garden-content .tab-stats .canvas-fullview .empty-canvas h3{margin:0 0 .75rem;font-size:22px;color:#374151}.garden-editor .garden-content .tab-potager .canvas-fullview .empty-canvas p,.garden-editor .garden-content .tab-calendar .canvas-fullview .empty-canvas p,.garden-editor .garden-content .tab-weather .canvas-fullview .empty-canvas p,.garden-editor .garden-content .tab-stats .canvas-fullview .empty-canvas p{margin:0 0 2rem;color:#6b7280;font-size:15px}.garden-editor .garden-content .tab-potager .canvas-fullview .empty-canvas .btn-primary,.garden-editor .garden-content .tab-calendar .canvas-fullview .empty-canvas .btn-primary,.garden-editor .garden-content .tab-weather .canvas-fullview .empty-canvas .btn-primary,.garden-editor .garden-content .tab-stats .canvas-fullview .empty-canvas .btn-primary{padding:.875rem 1.75rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;font-weight:500;font-size:15px;cursor:pointer;transition:all .2s}.garden-editor .garden-content .tab-potager .canvas-fullview .empty-canvas .btn-primary:hover,.garden-editor .garden-content .tab-calendar .canvas-fullview .empty-canvas .btn-primary:hover,.garden-editor .garden-content .tab-weather .canvas-fullview .empty-canvas .btn-primary:hover,.garden-editor .garden-content .tab-stats .canvas-fullview .empty-canvas .btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #6366f159}.garden-editor .garden-content .tab-weather .weather-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}@media(max-width:768px){.garden-editor .garden-content .tab-weather .weather-grid{grid-template-columns:1fr}}.garden-editor .garden-content .tab-weather .weather-grid--2col{grid-template-columns:repeat(2,1fr)}@media(max-width:768px){.garden-editor .garden-content .tab-weather .weather-grid--2col{grid-template-columns:1fr}}.garden-editor .garden-content .tab-weather .weather-card{background:#f8fafc;border-radius:10px;padding:1.25rem;display:flex;align-items:flex-start;gap:.75rem;border:1px solid #e5e7eb}.garden-editor .garden-content .tab-weather .weather-card--temp{border-left:3px solid #f97316}.garden-editor .garden-content .tab-weather .weather-card--humidity{border-left:3px solid #3b82f6}.garden-editor .garden-content .tab-weather .weather-card--rain{border-left:3px solid #60a5fa}.garden-editor .garden-content .tab-weather .weather-card--sun{border-left:3px solid #f59e0b}.garden-editor .garden-content .tab-weather .weather-card--pressure{border-left:3px solid #8b5cf6}.garden-editor .garden-content .tab-weather .weather-card__icon{font-size:28px;flex-shrink:0}.garden-editor .garden-content .tab-weather .weather-card__body{flex:1;min-width:0}.garden-editor .garden-content .tab-weather .weather-card__value{font-size:22px;font-weight:700;color:#1f2937}.garden-editor .garden-content .tab-weather .weather-card__label{font-size:13px;color:#6b7280;margin-top:2px}.garden-editor .garden-content .tab-weather .weather-card__range{display:flex;gap:.75rem;font-size:13px;color:#6b7280;margin-top:4px}.garden-editor .garden-content .tab-weather .weather-card__detail{font-size:12px;color:#9ca3af;margin-top:3px}.garden-editor .garden-content .tab-weather .weather-card__bar{height:6px;background:#e5e7eb;border-radius:3px;margin-top:6px;overflow:hidden}.garden-editor .garden-content .tab-weather .weather-card__bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;transition:width .3s}.garden-editor .garden-content .tab-weather .weather-card__risk{font-size:12px;font-weight:600;padding:2px 8px;border-radius:4px;margin-top:6px;display:inline-block}.garden-editor .garden-content .tab-weather .weather-card__risk--high{background:#fef2f2;color:#dc2626}.garden-editor .garden-content .tab-weather .weather-card__risk--medium{background:#fff7ed;color:#ea580c}.garden-editor .garden-content .tab-weather .weather-card__separator{width:1px;align-self:stretch;background:#e5e7eb;margin:0 .25rem}@media(max-width:768px){.garden-editor .garden-content .tab-weather .weather-card__separator{display:none}}.garden-editor .garden-content .tab-weather .weather-forecast{background:#f8fafc;border-radius:10px;padding:1.25rem;border:1px solid #e5e7eb;margin-top:1rem}.garden-editor .garden-content .tab-weather .weather-forecast h3{margin:0 0 1rem}.garden-editor .garden-content .tab-weather .forecast-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.75rem}@media(max-width:768px){.garden-editor .garden-content .tab-weather .forecast-grid{grid-template-columns:repeat(3,1fr)}}.garden-editor .garden-content .tab-weather .forecast-day{text-align:center;padding:.75rem .5rem;background:#fff;border-radius:8px;border:1px solid #e5e7eb}.garden-editor .garden-content .tab-weather .forecast-day__name{font-size:13px;font-weight:600;color:#374151;margin-bottom:4px}.garden-editor .garden-content .tab-weather .forecast-day__icon{font-size:24px;margin:4px 0}.garden-editor .garden-content .tab-weather .forecast-day__temps{font-size:14px;display:flex;justify-content:center;gap:6px}.garden-editor .garden-content .tab-weather .forecast-day__max{font-weight:600;color:#1f2937}.garden-editor .garden-content .tab-weather .forecast-day__min{color:#9ca3af}.garden-editor .garden-content .tab-weather .forecast-day__rain{font-size:11px;color:#3b82f6;margin-top:4px}.garden-editor .garden-content .tab-weather .weather-alerts{margin-top:1rem}.garden-editor .garden-content .tab-weather .alerts-list{display:flex;flex-direction:column;gap:.5rem}.garden-editor .garden-content .tab-weather .alert-item{padding:.75rem 1rem;border-radius:8px;border-left:3px solid}.garden-editor .garden-content .tab-weather .alert-item--warning{background:#fff7ed;border-color:#f97316}.garden-editor .garden-content .tab-weather .alert-item--info{background:#eff6ff;border-color:#3b82f6}.garden-editor .garden-content .tab-weather .alert-item--success{background:#f0fdf4;border-color:#22c55e}.garden-editor .garden-content .tab-weather .alert-item__title{font-weight:600;font-size:14px;color:#1f2937}.garden-editor .garden-content .tab-weather .alert-item__text{font-size:13px;color:#6b7280;margin-top:2px}.garden-editor .garden-content .tab-calendar .calendar-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.garden-editor .garden-content .tab-calendar .calendar-header h2{margin:0}.garden-editor .garden-content .tab-calendar .calendar-meta{display:flex;gap:.5rem;flex-wrap:wrap}.garden-editor .garden-content .tab-calendar .calendar-meta .badge{font-size:12px;padding:4px 10px;background:#eff6ff;color:#3b82f6;border-radius:20px;font-weight:500}.garden-editor .garden-content .tab-calendar .calendar-meta .badge--frost{background:#f0f9ff;color:#0ea5e9}.garden-editor .garden-content .tab-calendar .calendar-meta .badge--plan{background:#ecfdf5;color:#059669}.garden-editor .garden-content .tab-calendar .calendar-nav{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem;padding:.75rem;background:#f8fafc;border-radius:8px}.garden-editor .garden-content .tab-calendar .calendar-nav button{background:#fff;border:1px solid #e5e7eb;padding:.5rem 1rem;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:#374151;transition:all .2s}.garden-editor .garden-content .tab-calendar .calendar-nav button:hover{background:#f0f0ff;border-color:#6366f1;color:#6366f1}.garden-editor .garden-content .tab-calendar .calendar-nav__month{font-size:16px;font-weight:700;color:#1f2937;min-width:120px;text-align:center}.garden-editor .garden-content .tab-calendar .dashboard-actions{display:flex;flex-direction:column;gap:1.5rem}.garden-editor .garden-content .tab-calendar .action-group__title{font-size:16px;font-weight:700;margin:0 0 .25rem;color:#1f2937}.garden-editor .garden-content .tab-calendar .action-group__subtitle{font-size:12px;color:#9ca3af;margin:0 0 .75rem}.garden-editor .garden-content .tab-calendar .action-group--plan .action-group__title{color:#059669}.garden-editor .garden-content .tab-calendar .action-group--seed .action-group__title{color:#d97706}.garden-editor .garden-content .tab-calendar .action-group--companion .action-group__title{color:#7c3aed}.garden-editor .garden-content .tab-calendar .action-group--general .action-group__title{color:#6b7280}.garden-editor .garden-content .tab-calendar .action-list{display:flex;flex-direction:column;gap:.5rem}.garden-editor .garden-content .tab-calendar .action-card{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem 1rem;border-radius:8px;border:1px solid #e5e7eb;background:#fafbfc;transition:all .2s}.garden-editor .garden-content .tab-calendar .action-card:hover{background:#f0f0ff;border-color:#c7d2fe}.garden-editor .garden-content .tab-calendar .action-card--seeding{border-left:3px solid #22c55e}.garden-editor .garden-content .tab-calendar .action-card--harvest{border-left:3px solid #f59e0b}.garden-editor .garden-content .tab-calendar .action-card--transplant{border-left:3px solid #6366f1}.garden-editor .garden-content .tab-calendar .action-card--maintenance{border-left:3px solid #8b5cf6}.garden-editor .garden-content .tab-calendar .action-card--general{border-left:3px solid #9ca3af}.garden-editor .garden-content .tab-calendar .action-card--done{opacity:.5;text-decoration:line-through;background:#f8f8f8}.garden-editor .garden-content .tab-calendar .action-card--suggestion{border-style:dashed;background:#faf5ff}.garden-editor .garden-content .tab-calendar .action-card__check{background:none;border:none;font-size:18px;cursor:pointer;padding:0;flex-shrink:0;line-height:1}.garden-editor .garden-content .tab-calendar .action-card__icon{font-size:20px;flex-shrink:0}.garden-editor .garden-content .tab-calendar .action-card__body{flex:1;min-width:0}.garden-editor .garden-content .tab-calendar .action-card__title{font-size:14px;font-weight:500;color:#1f2937}.garden-editor .garden-content .tab-calendar .action-card__timing{font-size:12px;color:#0ea5e9;margin-top:2px}.garden-editor .garden-content .tab-calendar .action-card__tip{font-size:12px;color:#6b7280;margin-top:2px;font-style:italic}.garden-editor .garden-content .tab-calendar .action-card__priority{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;flex-shrink:0;white-space:nowrap}.garden-editor .garden-content .tab-calendar .action-card__priority--critical{background:#dcfce7;color:#166534}.garden-editor .garden-content .tab-calendar .action-card__priority--companion{background:#ede9fe;color:#7c3aed}.garden-editor .garden-content .tab-calendar .upcoming-section{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.garden-editor .garden-content .tab-calendar .upcoming-section h3{margin:0 0 .75rem;font-size:15px}.garden-editor .garden-content .tab-calendar .upcoming-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}@media(max-width:768px){.garden-editor .garden-content .tab-calendar .upcoming-grid{grid-template-columns:1fr}}.garden-editor .garden-content .tab-calendar .upcoming-card{display:flex;flex-direction:column;gap:.35rem;padding:.75rem 1rem;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:all .2s;text-align:left}.garden-editor .garden-content .tab-calendar .upcoming-card:hover{background:#f0f0ff;border-color:#c7d2fe}.garden-editor .garden-content .tab-calendar .upcoming-card__month{font-size:14px;font-weight:700;color:#1f2937}.garden-editor .garden-content .tab-calendar .upcoming-card__counts{display:flex;flex-direction:column;gap:.15rem}.garden-editor .garden-content .tab-calendar .upcoming-card__plan{font-size:12px;color:#059669;font-weight:600}.garden-editor .garden-content .tab-calendar .upcoming-card__total{font-size:11px;color:#9ca3af}.garden-editor .garden-content .tab-calendar .calendar-empty{text-align:center;padding:2rem;color:#6b7280}.garden-editor .garden-content .tab-calendar .calendar-empty p{margin:.5rem 0}.garden-editor .garden-content .tab-calendar .calendar-empty__hint{font-size:13px;color:#9ca3af}.garden-editor .garden-content .tab-calendar .calendar-yearly{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.garden-editor .garden-content .tab-calendar .calendar-yearly h3{margin:0 0 .75rem}.garden-editor .garden-content .tab-calendar .calendar-yearly__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}@media(max-width:768px){.garden-editor .garden-content .tab-calendar .calendar-yearly__grid{grid-template-columns:repeat(4,1fr)}}.garden-editor .garden-content .tab-calendar .calendar-yearly__month{display:flex;flex-direction:column;align-items:center;padding:.5rem;border-radius:8px;border:1px solid #e5e7eb;background:#fff;cursor:pointer;transition:all .2s}.garden-editor .garden-content .tab-calendar .calendar-yearly__month:hover{background:#f0f0ff;border-color:#c7d2fe}.garden-editor .garden-content .tab-calendar .calendar-yearly__month.active{background:#eef2ff;border-color:#6366f1;box-shadow:0 0 0 1px #6366f1}.garden-editor .garden-content .tab-calendar .calendar-yearly__month.has-plan{border-color:#86efac;background:#f0fdf4}.garden-editor .garden-content .tab-calendar .calendar-yearly__month.has-events .calendar-yearly__count{display:block}.garden-editor .garden-content .tab-calendar .calendar-yearly__name{font-size:12px;font-weight:600;color:#374151}.garden-editor .garden-content .tab-calendar .calendar-yearly__count{display:none;font-size:11px;background:#6366f1;color:#fff;border-radius:10px;padding:1px 6px;margin-top:2px;font-weight:600}.garden-editor .garden-content .tab-calendar .calendar-yearly__count--plan{background:#059669}.garden-editor .garden-content .tab-stats .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem}@media(max-width:768px){.garden-editor .garden-content .tab-stats .stats-grid{grid-template-columns:repeat(2,1fr)}}.garden-editor .garden-content .tab-stats .stat-card{background:#f8fafc;border-radius:10px;padding:1rem;text-align:center;border:1px solid #e5e7eb}.garden-editor .garden-content .tab-stats .stat-card__icon{font-size:24px;margin-bottom:4px}.garden-editor .garden-content .tab-stats .stat-card__value{font-size:20px;font-weight:700;color:#1f2937}.garden-editor .garden-content .tab-stats .stat-card__label{font-size:12px;color:#6b7280;margin-top:2px}.garden-editor .garden-content .tab-stats .stats-section{margin-bottom:1.5rem}.garden-editor .garden-content .tab-stats .zone-breakdown{display:flex;flex-direction:column;gap:.5rem}.garden-editor .garden-content .tab-stats .zone-breakdown__item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:#f8fafc;border-radius:6px;border:1px solid #e5e7eb}.garden-editor .garden-content .tab-stats .zone-breakdown__label{font-size:14px;color:#374151}.garden-editor .garden-content .tab-stats .zone-breakdown__count{font-size:14px;font-weight:700;color:#6366f1}.garden-editor .garden-content .tab-stats .family-tags{display:flex;flex-wrap:wrap;gap:.5rem}.garden-editor .garden-content .tab-stats .family-tag{font-size:13px;padding:4px 12px;background:#ede9fe;color:#5b21b6;border-radius:20px;font-weight:500}.garden-editor .garden-content .tab-stats .family-tag--plant{background:#dcfce7;color:#166534}.garden-editor .garden-content .tab-stats .coverage-bar{display:flex;align-items:center;gap:1rem}.garden-editor .garden-content .tab-stats .coverage-bar__track{flex:1;height:12px;background:#e5e7eb;border-radius:6px;overflow:hidden}.garden-editor .garden-content .tab-stats .coverage-bar__fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:6px;transition:width .5s ease}.garden-editor .garden-content .tab-stats .coverage-bar__label{font-size:14px;font-weight:600;color:#374151;white-space:nowrap}.garden-editor .garden-content .tab-potager .empty-tab,.garden-editor .garden-content .tab-overview .empty-tab{text-align:center;padding:3rem 2rem;color:#6b7280;font-size:15px}.garden-editor .garden-content .tab-potager .empty-tab p,.garden-editor .garden-content .tab-overview .empty-tab p{margin:.5rem 0}.garden-editor .garden-content .tab-potager .potager-section,.garden-editor .garden-content .tab-overview .potager-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #f3f4f6}.garden-editor .garden-content .tab-potager .potager-section:last-child,.garden-editor .garden-content .tab-overview .potager-section:last-child{border-bottom:none}.garden-editor .garden-content .tab-potager .compatibility-score,.garden-editor .garden-content .tab-overview .compatibility-score{display:flex;align-items:center;gap:1.5rem;padding:1rem;background:#f8fafc;border-radius:12px;border:1px solid #e5e7eb}.garden-editor .garden-content .tab-potager .score-circle,.garden-editor .garden-content .tab-overview .score-circle{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:4px solid}.garden-editor .garden-content .tab-potager .score-circle.score-good,.garden-editor .garden-content .tab-overview .score-circle.score-good{border-color:#22c55e;background:#f0fdf4}.garden-editor .garden-content .tab-potager .score-circle.score-medium,.garden-editor .garden-content .tab-overview .score-circle.score-medium{border-color:#f59e0b;background:#fffbeb}.garden-editor .garden-content .tab-potager .score-circle.score-low,.garden-editor .garden-content .tab-overview .score-circle.score-low{border-color:#ef4444;background:#fef2f2}.garden-editor .garden-content .tab-potager .score-circle .score-value,.garden-editor .garden-content .tab-overview .score-circle .score-value{font-size:22px;font-weight:700;color:#1f2937}.garden-editor .garden-content .tab-potager .score-details,.garden-editor .garden-content .tab-overview .score-details{display:flex;flex-direction:column;gap:.25rem;font-size:14px}.garden-editor .garden-content .tab-potager .score-details .score-compat,.garden-editor .garden-content .tab-overview .score-details .score-compat{color:#16a34a}.garden-editor .garden-content .tab-potager .score-details .score-incompat,.garden-editor .garden-content .tab-overview .score-details .score-incompat{color:#dc2626}.garden-editor .garden-content .tab-potager .association-badges,.garden-editor .garden-content .tab-overview .association-badges{display:flex;flex-wrap:wrap;gap:.5rem}.garden-editor .garden-content .tab-potager .association-badge,.garden-editor .garden-content .tab-overview .association-badge{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:20px;font-size:13px}.garden-editor .garden-content .tab-potager .association-badge .badge-plant,.garden-editor .garden-content .tab-overview .association-badge .badge-plant{font-weight:600}.garden-editor .garden-content .tab-potager .association-badge .badge-separator,.garden-editor .garden-content .tab-overview .association-badge .badge-separator{font-weight:400;opacity:.7}.garden-editor .garden-content .tab-potager .association-badge.badge-good,.garden-editor .garden-content .tab-overview .association-badge.badge-good{background:#ecfdf5;border:1px solid #a7f3d0}.garden-editor .garden-content .tab-potager .association-badge.badge-good .badge-plant,.garden-editor .garden-content .tab-overview .association-badge.badge-good .badge-plant{color:#166534}.garden-editor .garden-content .tab-potager .association-badge.badge-good .badge-separator,.garden-editor .garden-content .tab-overview .association-badge.badge-good .badge-separator{color:#16a34a}.garden-editor .garden-content .tab-potager .association-badge.badge-bad,.garden-editor .garden-content .tab-overview .association-badge.badge-bad{background:#fef2f2;border:1px solid #fecaca}.garden-editor .garden-content .tab-potager .association-badge.badge-bad .badge-plant,.garden-editor .garden-content .tab-overview .association-badge.badge-bad .badge-plant{color:#991b1b}.garden-editor .garden-content .tab-potager .association-badge.badge-bad .badge-separator,.garden-editor .garden-content .tab-overview .association-badge.badge-bad .badge-separator{color:#dc2626}.garden-editor .garden-content .tab-potager .yield-total,.garden-editor .garden-content .tab-overview .yield-total{padding:.75rem 1rem;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-radius:8px;margin-bottom:.75rem;font-size:15px;color:#166534}.garden-editor .garden-content .tab-potager .yield-table,.garden-editor .garden-content .tab-overview .yield-table{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.garden-editor .garden-content .tab-potager .yield-header,.garden-editor .garden-content .tab-potager .yield-row,.garden-editor .garden-content .tab-overview .yield-header,.garden-editor .garden-content .tab-overview .yield-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.5rem;padding:.625rem .875rem;font-size:13px}.garden-editor .garden-content .tab-potager .yield-header,.garden-editor .garden-content .tab-overview .yield-header{background:#f3f4f6;font-weight:600;color:#374151}.garden-editor .garden-content .tab-potager .yield-row,.garden-editor .garden-content .tab-overview .yield-row{border-top:1px solid #f3f4f6;color:#4b5563}.garden-editor .garden-content .tab-potager .yield-row:nth-child(2n),.garden-editor .garden-content .tab-overview .yield-row:nth-child(2n){background:#fafafa}.garden-editor .garden-content .tab-potager .rotation-hint,.garden-editor .garden-content .tab-overview .rotation-hint{font-size:13px;color:#6b7280;margin:0 0 .75rem}.garden-editor .garden-content .tab-potager .family-rotation-grid,.garden-editor .garden-content .tab-overview .family-rotation-grid{display:flex;flex-wrap:wrap;gap:.5rem}.garden-editor .garden-content .tab-potager .rotation-card,.garden-editor .garden-content .tab-overview .rotation-card{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;background:#ede9fe;border-radius:20px;font-size:13px}.garden-editor .garden-content .tab-potager .rotation-card .rotation-family,.garden-editor .garden-content .tab-overview .rotation-card .rotation-family{font-weight:600;color:#5b21b6}.garden-editor .garden-content .tab-potager .rotation-card .rotation-count,.garden-editor .garden-content .tab-overview .rotation-card .rotation-count{color:#7c3aed}.garden-editor .garden-content .garden-plan{margin-bottom:2rem}.garden-editor .garden-content .garden-plan .plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.garden-editor .garden-content .garden-plan .plan-header h2{margin:0!important}.garden-editor .garden-content .garden-plan .plan-header .plan-actions{display:flex;gap:.5rem}.garden-editor .garden-content .garden-plan .btn-outline{padding:.5rem 1rem;background:transparent;border:1.5px solid #6366f1;color:#6366f1;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.garden-editor .garden-content .garden-plan .btn-outline:hover{background:#6366f1;color:#fff}.garden-editor .garden-content .garden-plan .btn-sm{padding:.5rem 1rem;font-size:13px;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.garden-editor .garden-content .garden-plan .btn-sm:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.garden-editor .garden-content .garden-plan .plan-preview-container{min-height:200px;border:1px solid #e5e7eb;border-radius:10px;overflow:hidden;background:#fafafa}.garden-editor .city-autocomplete{position:relative}.garden-editor .city-suggestions{position:absolute;top:100%;left:0;right:0;z-index:50;background:#fff;border:1px solid #e5e7eb;border-top:none;border-radius:0 0 8px 8px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto}.garden-editor .city-suggestion-item{display:flex;flex-direction:column;width:100%;padding:.625rem .875rem;border:none;background:none;text-align:left;cursor:pointer;transition:background .15s}.garden-editor .city-suggestion-item:hover{background:#f3f4f6}.garden-editor .city-suggestion-item .city-name{font-size:14px;font-weight:500;color:#1f2937}.garden-editor .city-suggestion-item .city-detail{font-size:12px;color:#6b7280}.garden-editor .readonly-canvas-modal{position:fixed;inset:2%;z-index:1100;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden}.garden-editor .readonly-canvas-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.garden-editor .readonly-canvas-modal .modal-header h3{margin:0;font-size:18px}.garden-editor .readonly-canvas-modal .readonly-canvas-body{flex:1;overflow:hidden}.garden-editor .garden-selector{padding:2rem;max-width:1200px;margin:0 auto;box-sizing:border-box}.garden-editor .garden-selector .selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}.garden-editor .garden-selector .selector-header h2{margin:0;font-size:28px;font-weight:700;color:#1f2937}.garden-editor .garden-selector .selector-header h2 .selector-count{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;margin-left:8px;font-size:14px;font-weight:600;color:#fff;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:14px;vertical-align:middle}.garden-editor .garden-selector .selector-header .btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.garden-editor .garden-selector .selector-header .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.garden-editor .garden-selector .empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a}.garden-editor .garden-selector .empty-state .empty-icon{font-size:80px;margin-bottom:1.5rem;opacity:.4}.garden-editor .garden-selector .empty-state h3{margin:0 0 .75rem;font-size:24px;color:#374151}.garden-editor .garden-selector .empty-state p{margin:0 0 2rem;color:#6b7280;font-size:16px}.garden-editor .garden-selector .empty-state .btn-primary-large{padding:1rem 2rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;font-weight:600;font-size:16px;cursor:pointer;transition:all .2s}.garden-editor .garden-selector .empty-state .btn-primary-large:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.garden-editor .garden-selector .gardens-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.garden-editor .garden-selector .gardens-grid .garden-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000014;transition:all .25s ease;border:1px solid #e5e7eb}.garden-editor .garden-selector .gardens-grid .garden-card:hover{box-shadow:0 8px 24px #0000001a;border-color:#c7d2fe}.garden-editor .garden-selector .gardens-grid .garden-card__visual{position:relative;overflow:hidden;height:160px}.garden-editor .garden-selector .gardens-grid .garden-card__visual--has-preview{background:#f5f0eb}.garden-editor .garden-selector .gardens-grid .garden-card__visual-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.3) 100%);display:flex;align-items:flex-end;justify-content:space-between;padding:.75rem;gap:.5rem;flex-wrap:wrap;pointer-events:none}.garden-editor .garden-selector .gardens-grid .garden-card__type-badge{background:#ffffffeb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#1f2937;padding:.3rem .7rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap}.garden-editor .garden-selector .gardens-grid .garden-card__shared-badge{background:#6366f1e6;color:#fff;padding:.3rem .7rem;border-radius:20px;font-size:.72rem;font-weight:600;white-space:nowrap}.garden-editor .garden-selector .gardens-grid .garden-card__frozen-badge{background:#ef4444e6;color:#fff;padding:.3rem .7rem;border-radius:20px;font-size:.72rem;font-weight:600;white-space:nowrap}.garden-editor .garden-selector .gardens-grid .garden-card__body{padding:1rem 1.25rem}.garden-editor .garden-selector .gardens-grid .garden-card__header-row{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.garden-editor .garden-selector .gardens-grid .garden-card__name{margin:0;font-size:1.15rem;font-weight:700;color:#1f2937;line-height:1.3}.garden-editor .garden-selector .gardens-grid .garden-card__location{font-size:.82rem;color:#6b7280;white-space:nowrap}.garden-editor .garden-selector .gardens-grid .garden-card__stats-line{display:flex;align-items:center;gap:.5rem;margin:0 0 .75rem;font-size:.9rem;color:#6366f1;font-weight:600}.garden-editor .garden-selector .gardens-grid .garden-card__stats-sep{color:#cbd5e1}.garden-editor .garden-selector .gardens-grid .garden-card__stats-value{white-space:nowrap}.garden-editor .garden-selector .gardens-grid .garden-card__household{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;background:#ede9fe;border:1px solid #ddd6fe;border-radius:8px;font-size:.78rem;font-weight:500;color:#5b21b6;text-decoration:none;cursor:pointer;transition:all .2s;white-space:nowrap}.garden-editor .garden-selector .gardens-grid .garden-card__household:hover{background:#ddd6fe;border-color:#c4b5fd}.garden-editor .garden-selector .gardens-grid .garden-card__footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid #f1f5f9}.garden-editor .garden-selector .gardens-grid .garden-card__footer-left{display:flex;align-items:center;gap:.5rem}.garden-editor .garden-selector .gardens-grid .garden-card__footer .btn-open{background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-weight:600;cursor:pointer;padding:.45rem 1rem;font-size:.85rem;border-radius:8px;transition:all .2s}.garden-editor .garden-selector .gardens-grid .garden-card__footer .btn-open:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.garden-editor .garden-selector .gardens-grid .garden-card__footer .btn-link{background:transparent;border:none;color:#6366f1;font-weight:600;cursor:pointer;padding:.4rem 0;font-size:.85rem;transition:all .2s}.garden-editor .garden-selector .gardens-grid .garden-card__footer .btn-link:hover{color:#4f46e5}.garden-editor .garden-selector .gardens-grid .garden-card__footer .garden-card__actions{display:flex;gap:.4rem}.garden-editor .garden-selector .gardens-grid .garden-card__footer .garden-card__actions .btn-icon{background:transparent;border:1px solid #e5e7eb;border-radius:8px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.9rem;transition:all .15s ease}.garden-editor .garden-selector .gardens-grid .garden-card__footer .garden-card__actions .btn-icon.btn-edit:hover{background:#ede9fe;border-color:#6366f1}.garden-editor .garden-selector .gardens-grid .garden-card__footer .garden-card__actions .btn-icon.btn-delete:hover{background:#fee2e2;border-color:#ef4444}.garden-editor .garden-selector .gardens-grid .garden-card--frozen{opacity:.55;cursor:not-allowed;border:2px dashed #94a3b8}.garden-editor .garden-selector .gardens-grid .garden-card--frozen:hover{box-shadow:0 2px 8px #00000014}.garden-editor .garden-selector .gardens-grid .garden-card--frozen .garden-card__visual-overlay{background:linear-gradient(180deg,#00000026,#00000080)}.garden-editor .garden-selector .selector-header__right{display:flex;align-items:center;gap:.75rem}.garden-editor .garden-selector .garden-limit-badge{display:inline-flex;align-items:center;padding:.35rem .75rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;font-size:.85rem;font-weight:600;color:#475569}.garden-editor .garden-selector .garden-frozen-banner,.garden-editor .garden-selector .garden-limit-banner{margin-bottom:1.5rem;padding:1rem 1.25rem;border-radius:10px;font-size:.9rem}.garden-editor .garden-selector .garden-frozen-banner span,.garden-editor .garden-selector .garden-limit-banner span{font-weight:600;display:block;margin-bottom:.3rem}.garden-editor .garden-selector .garden-frozen-banner p,.garden-editor .garden-selector .garden-limit-banner p{margin:0 0 .5rem;font-size:.82rem;color:#64748b}.garden-editor .garden-selector .garden-frozen-banner .btn-secondary,.garden-editor .garden-selector .garden-limit-banner .btn-secondary{margin-top:.5rem;padding:.4rem 1rem;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-weight:500;font-size:.82rem}.garden-editor .garden-selector .garden-frozen-banner .btn-secondary:hover,.garden-editor .garden-selector .garden-limit-banner .btn-secondary:hover{background:#f8fafc}.garden-editor .garden-selector .garden-frozen-banner{background:#fef2f2;border:1px solid #fecaca}.garden-editor .garden-selector .garden-limit-banner{background:#fffbeb;border:1px solid #fde68a}.garden-editor .modal-overlay{position:fixed;inset:0;background:#00000080;z-index:999}.garden-editor .create-garden-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;width:90%;max-width:500px;max-height:90vh;overflow-y:auto;z-index:1000}.garden-editor .create-garden-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e5e7eb}.garden-editor .create-garden-modal .modal-header h3{margin:0;font-size:20px;font-weight:600;color:#1f2937}.garden-editor .create-garden-modal .modal-header .modal-close{background:transparent;border:none;font-size:24px;color:#9ca3af;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.garden-editor .create-garden-modal .modal-header .modal-close:hover{background:#f3f4f6;color:#4b5563}.garden-editor .create-garden-modal form{padding:1.5rem}.garden-editor .create-garden-modal form .form-group{margin-bottom:1.25rem}.garden-editor .create-garden-modal form .form-group label{display:block;margin-bottom:.5rem;font-size:14px;font-weight:500;color:#374151}.garden-editor .create-garden-modal form .form-group input{width:100%;padding:.625rem .875rem;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:all .2s}.garden-editor .create-garden-modal form .form-group input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f11a}.garden-editor .create-garden-modal form .form-group .computed-area{padding:.625rem .875rem;background:#f0fdf4;border:1px solid #86efac;border-radius:6px;font-size:15px;font-weight:600;color:#166534}.garden-editor .create-garden-modal form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.garden-editor .create-garden-modal form .geolocation-section{margin-bottom:1.25rem}.garden-editor .create-garden-modal form .geolocation-section .btn-geolocation{width:100%;padding:.75rem;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;font-weight:500;color:#4b5563;cursor:pointer;transition:all .2s}.garden-editor .create-garden-modal form .geolocation-section .btn-geolocation:hover:not(:disabled){background:#e5e7eb}.garden-editor .create-garden-modal form .geolocation-section .btn-geolocation:disabled{opacity:.5;cursor:not-allowed}.garden-editor .create-garden-modal form .geolocation-section .geolocation-hint{margin:.5rem 0 0;font-size:12px;color:#6b7280}.garden-editor .create-garden-modal form .form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.garden-editor .create-garden-modal form .form-actions button{padding:.625rem 1.25rem;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s}.garden-editor .create-garden-modal form .form-actions button.btn-secondary{background:#f3f4f6;color:#4b5563}.garden-editor .create-garden-modal form .form-actions button.btn-secondary:hover{background:#e5e7eb}.garden-editor .create-garden-modal form .form-actions button.btn-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.garden-editor .create-garden-modal form .form-actions button.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}.garden-editor .create-garden-modal form .form-actions button.btn-danger{background:#ef4444;color:#fff}.garden-editor .create-garden-modal form .form-actions button.btn-danger:hover{background:#dc2626}.garden-editor .create-garden-modal.delete-confirm-modal .delete-warning{margin:0 0 1rem;padding:1rem;background:#fef2f2;border-radius:8px;color:#991b1b;font-size:14px;line-height:1.5}.garden-editor .editor-empty{text-align:center;padding:4rem 2rem}.garden-editor .editor-empty h2{margin:0 0 1rem;font-size:24px;color:#374151}.garden-editor .editor-empty p{margin:0 0 2rem;color:#6b7280}.garden-editor .editor-empty .btn-primary{padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s}.garden-editor .editor-empty .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #6366f159}@media(min-width:769px)and (max-width:1024px){.garden-editor .garden-content,.garden-editor .garden-selector{padding:1.5rem}.garden-editor .garden-selector .gardens-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.garden-editor .garden-detail-header .header-content{flex-direction:column;align-items:flex-start;gap:1rem}.garden-editor .garden-detail-header .header-content .header-actions{width:100%}.garden-editor .garden-detail-header .header-content .header-actions button{flex:1}.garden-editor .garden-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.garden-editor .garden-tabs .tab{white-space:nowrap;min-height:44px}.garden-editor .garden-content{padding:1rem}.garden-editor .garden-content .tab-overview .overview-section .info-grid,.garden-editor .garden-content .tab-overview .overview-section .actions-grid{grid-template-columns:1fr}.garden-editor .garden-selector{padding:1rem}.garden-editor .garden-selector .gardens-grid{grid-template-columns:1fr}}@media(max-width:480px){.garden-editor .garden-detail-header .header-content h1{font-size:1.25rem}.garden-editor .garden-tabs .tab{font-size:.8rem;padding:.5rem .75rem}.garden-editor .garden-content{padding:.75rem}}.stat-card__sub{font-size:11px;color:#6b7280;margin-top:2px}.garden-card__soil-badge{font-size:12px;font-weight:600}.badge-soil{background:linear-gradient(135deg,#fef3c7,#fde68a)!important;color:#92400e!important}.snapshot-preview-modal{position:fixed;inset:5%;z-index:1100;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden}.snapshot-preview-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.snapshot-preview-modal .modal-header h3{margin:0;font-size:18px}.snapshot-preview-modal .snapshot-preview-body{flex:1;overflow:auto;padding:1rem}.snapshot-preview-modal .snapshot-preview-notes{padding:.75rem 1.5rem;border-top:1px solid #e5e7eb;background:#f9fafb}.snapshot-preview-modal .snapshot-preview-notes p{margin:0;font-size:14px;color:#374151}.snapshot-modal-body{padding:1.5rem}.snapshot-modal-body .snapshot-info{font-size:1rem;font-weight:600;color:#1f2937;padding:.75rem 1rem;background:#f0fdf4;border-radius:8px;border:1px solid #bbf7d0;margin-bottom:1rem}.tab-history .history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:.5rem}.tab-history .history-header h2{margin:0}.tab-history .history-empty{text-align:center;padding:3rem 2rem;color:#6b7280}.tab-history .history-empty__icon{font-size:3rem;margin-bottom:.75rem}.tab-history .history-empty h3{color:#1f2937;margin:0 0 .5rem}.tab-history .history-empty p{margin:0 0 1.25rem;font-size:14px}.tab-history .history-timeline{display:flex;flex-direction:column;gap:0}.tab-history .history-entry{position:relative;padding-left:2rem;padding-bottom:1.5rem}.tab-history .history-entry__dot{position:absolute;left:0;top:6px;width:14px;height:14px;border-radius:50%;background:#22c55e;border:3px solid #dcfce7;z-index:1}.tab-history .history-entry__line{position:absolute;left:6px;top:20px;bottom:0;width:2px;background:#e5e7eb}.tab-history .history-entry__content{background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:1rem}.tab-history .history-entry__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}@media(max-width:480px){.tab-history .history-entry__header{flex-direction:column;align-items:flex-start;gap:2px}}.tab-history .history-entry__season{font-weight:700;font-size:1rem;color:#1f2937}.tab-history .history-entry__date{font-size:.8rem;color:#9ca3af}.tab-history .history-entry__meta{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem}.tab-history .history-entry__badge{font-size:12px;padding:2px 10px;background:#e0f2fe;color:#0369a1;border-radius:12px;font-weight:500}.tab-history .history-entry__notes{font-size:.85rem;color:#4b5563;margin:0 0 .5rem;line-height:1.5}.tab-history .history-entry__actions{display:flex;gap:.5rem;align-items:center}.btn-danger-text{color:#dc2626!important}.btn-danger-text:hover{background:#ef444414!important}.btn-ghost{background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:6px;transition:background .15s}.btn-ghost:hover{background:#f3f4f6}.rbc-btn{color:inherit;font:inherit;margin:0}button.rbc-btn{overflow:visible;text-transform:none;-webkit-appearance:button;-moz-appearance:button;appearance:button;cursor:pointer}button[disabled].rbc-btn{cursor:not-allowed}button.rbc-input::-moz-focus-inner{border:0;padding:0}.rbc-calendar{-webkit-box-sizing:border-box;box-sizing:border-box;height:100%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-align:stretch;-ms-flex-align:stretch;align-items:stretch}.rbc-m-b-negative-3{margin-bottom:-3px}.rbc-h-full{height:100%}.rbc-calendar *,.rbc-calendar *:before,.rbc-calendar *:after{-webkit-box-sizing:inherit;box-sizing:inherit}.rbc-abs-full,.rbc-row-bg{overflow:hidden;position:absolute;inset:0}.rbc-ellipsis,.rbc-show-more,.rbc-row-segment .rbc-event-content,.rbc-event-label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rbc-rtl{direction:rtl}.rbc-off-range{color:#999}.rbc-off-range-bg{background:#e6e6e6}.rbc-header{overflow:hidden;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;text-overflow:ellipsis;white-space:nowrap;padding:0 3px;text-align:center;vertical-align:middle;font-weight:700;font-size:90%;min-height:0;border-bottom:1px solid #ddd}.rbc-header+.rbc-header{border-left:1px solid #ddd}.rbc-rtl .rbc-header+.rbc-header{border-left-width:0;border-right:1px solid #ddd}.rbc-header>a,.rbc-header>a:active,.rbc-header>a:visited{color:inherit;text-decoration:none}.rbc-button-link{color:inherit;background:none;margin:0;padding:0;border:none;cursor:pointer;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.rbc-row-content{position:relative;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;z-index:4}.rbc-row-content-scrollable{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;height:100%}.rbc-row-content-scrollable .rbc-row-content-scroll-container{height:100%;overflow-y:scroll;-ms-overflow-style:none;scrollbar-width:none}.rbc-row-content-scrollable .rbc-row-content-scroll-container::-webkit-scrollbar{display:none}.rbc-today{background-color:#eaf6ff}.rbc-toolbar{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:10px;font-size:16px}.rbc-toolbar .rbc-toolbar-label{-webkit-box-flex:1;-ms-flex-positive:1;flex-grow:1;padding:0 10px;text-align:center}.rbc-toolbar button{color:#373a3c;display:inline-block;margin:0;text-align:center;vertical-align:middle;background:none;background-image:none;border:1px solid #ccc;padding:.375rem 1rem;border-radius:4px;line-height:normal;white-space:nowrap}.rbc-toolbar button:active,.rbc-toolbar button.rbc-active{background-image:none;-webkit-box-shadow:inset 0 3px 5px rgba(0,0,0,.125);box-shadow:inset 0 3px 5px #00000020;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:active:hover,.rbc-toolbar button:active:focus,.rbc-toolbar button.rbc-active:hover,.rbc-toolbar button.rbc-active:focus{color:#373a3c;background-color:#d4d4d4;border-color:#8c8c8c}.rbc-toolbar button:focus{color:#373a3c;background-color:#e6e6e6;border-color:#adadad}.rbc-toolbar button:hover{color:#373a3c;cursor:pointer;background-color:#e6e6e6;border-color:#adadad}.rbc-btn-group{display:inline-block;white-space:nowrap}.rbc-btn-group>button:first-child:not(:last-child){border-top-right-radius:0;border-bottom-right-radius:0}.rbc-btn-group>button:last-child:not(:first-child){border-top-left-radius:0;border-bottom-left-radius:0}.rbc-rtl .rbc-btn-group>button:first-child:not(:last-child){border-radius:0 4px 4px 0}.rbc-rtl .rbc-btn-group>button:last-child:not(:first-child){border-radius:4px 0 0 4px}.rbc-btn-group>button:not(:first-child):not(:last-child){border-radius:0}.rbc-btn-group button+button{margin-left:-1px}.rbc-rtl .rbc-btn-group button+button{margin-left:0;margin-right:-1px}.rbc-btn-group+.rbc-btn-group,.rbc-btn-group+button{margin-left:10px}@media(max-width:767px){.rbc-toolbar{-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}}.rbc-event,.rbc-day-slot .rbc-background-event{border:none;-webkit-box-sizing:border-box;box-sizing:border-box;-webkit-box-shadow:none;box-shadow:none;margin:0;padding:2px 5px;background-color:#3174ad;border-radius:5px;color:#fff;cursor:pointer;width:100%;text-align:left}.rbc-slot-selecting .rbc-event,.rbc-slot-selecting .rbc-day-slot .rbc-background-event,.rbc-day-slot .rbc-slot-selecting .rbc-background-event{cursor:inherit;pointer-events:none}.rbc-event.rbc-selected,.rbc-day-slot .rbc-selected.rbc-background-event{background-color:#265985}.rbc-event:focus,.rbc-day-slot .rbc-background-event:focus{outline:5px auto #3b99fc}.rbc-event-label{font-size:80%}.rbc-event-overlaps{-webkit-box-shadow:-1px 1px 5px 0px rgba(51,51,51,.5);box-shadow:-1px 1px 5px #33333380}.rbc-event-continues-prior{border-top-left-radius:0;border-bottom-left-radius:0}.rbc-event-continues-after{border-top-right-radius:0;border-bottom-right-radius:0}.rbc-event-continues-earlier{border-top-left-radius:0;border-top-right-radius:0}.rbc-event-continues-later{border-bottom-left-radius:0;border-bottom-right-radius:0}.rbc-row{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-row-segment{padding:0 1px 1px}.rbc-selected-cell{background-color:#0000001a}.rbc-show-more{background-color:#ffffff4d;z-index:4;font-weight:700;font-size:85%;height:auto;line-height:normal;color:#3174ad}.rbc-show-more:hover,.rbc-show-more:focus{color:#265985}.rbc-month-view{position:relative;border:1px solid #ddd;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none;height:100%}.rbc-month-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-month-row{display:-webkit-box;display:-ms-flexbox;display:flex;position:relative;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px;overflow:hidden;height:100%}.rbc-month-row+.rbc-month-row{border-top:1px solid #ddd}.rbc-date-cell{-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;min-width:0;padding-right:5px;text-align:right}.rbc-date-cell.rbc-now{font-weight:700}.rbc-date-cell>a,.rbc-date-cell>a:active,.rbc-date-cell>a:visited{color:inherit;text-decoration:none}.rbc-row-bg{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:hidden;right:1px}.rbc-day-bg{-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%}.rbc-day-bg+.rbc-day-bg{border-left:1px solid #ddd}.rbc-rtl .rbc-day-bg+.rbc-day-bg{border-left-width:0;border-right:1px solid #ddd}.rbc-overlay{position:absolute;z-index:5;border:1px solid #e5e5e5;background-color:#fff;-webkit-box-shadow:0 5px 15px rgba(0,0,0,.25);box-shadow:0 5px 15px #00000040;padding:10px}.rbc-overlay>*+*{margin-top:1px}.rbc-overlay-header{border-bottom:1px solid #e5e5e5;margin:-10px -10px 5px;padding:2px 10px}.rbc-agenda-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;overflow:auto}.rbc-agenda-view table.rbc-agenda-table{width:100%;border:1px solid #ddd;border-spacing:0;border-collapse:collapse}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:5px 10px;vertical-align:top}.rbc-agenda-view table.rbc-agenda-table .rbc-agenda-time-cell{padding-left:15px;padding-right:15px;text-transform:lowercase}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table tbody>tr>td+td{border-left-width:0;border-right:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table tbody>tr+tr{border-top:1px solid #ddd}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{padding:3px 5px;text-align:left;border-bottom:1px solid #ddd}.rbc-rtl .rbc-agenda-view table.rbc-agenda-table thead>tr>th{text-align:right}.rbc-agenda-time-cell{text-transform:lowercase}.rbc-agenda-time-cell .rbc-continues-after:after{content:" »"}.rbc-agenda-time-cell .rbc-continues-prior:before{content:"« "}.rbc-agenda-date-cell,.rbc-agenda-time-cell{white-space:nowrap}.rbc-agenda-event-cell{width:100%}.rbc-time-column{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;min-height:100%}.rbc-time-column .rbc-timeslot-group{-webkit-box-flex:1;-ms-flex:1;flex:1}.rbc-timeslot-group{border-bottom:1px solid #ddd;min-height:40px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.rbc-time-gutter,.rbc-header-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-label{padding:0 5px}.rbc-day-slot{position:relative}.rbc-day-slot .rbc-events-container{inset:0;position:absolute;margin-right:10px}.rbc-day-slot .rbc-events-container.rbc-rtl{left:10px;right:0}.rbc-day-slot .rbc-event,.rbc-day-slot .rbc-background-event{border:1px solid #265985;display:-webkit-box;display:-ms-flexbox;display:flex;max-height:100%;min-height:20px;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-flow:column wrap;flex-flow:column wrap;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;overflow:hidden;position:absolute}.rbc-day-slot .rbc-background-event{opacity:.75}.rbc-day-slot .rbc-event-label{-webkit-box-flex:0;-ms-flex:none;flex:none;padding-right:5px;width:auto}.rbc-day-slot .rbc-event-content{width:100%;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;word-wrap:break-word;line-height:1;height:100%;min-height:1em}.rbc-day-slot .rbc-time-slot{border-top:1px solid #f7f7f7}.rbc-time-view-resources .rbc-time-gutter,.rbc-time-view-resources .rbc-time-header-gutter{position:sticky;left:0;background-color:#fff;border-right:1px solid #ddd;z-index:10;margin-right:-1px}.rbc-time-view-resources .rbc-time-header{overflow:hidden}.rbc-time-view-resources .rbc-time-header-content{min-width:auto;-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0;-ms-flex-preferred-size:0px;flex-basis:0px}.rbc-time-view-resources .rbc-time-header-cell-single-day{display:none}.rbc-time-view-resources .rbc-day-slot{min-width:140px}.rbc-time-view-resources .rbc-header,.rbc-time-view-resources .rbc-day-bg{width:140px;-webkit-box-flex:1;-ms-flex:1 1 0px;flex:1 1 0;-ms-flex-preferred-size:0 px;flex-basis:0 px}.rbc-time-header-content+.rbc-time-header-content{margin-left:-1px}.rbc-time-slot{-webkit-box-flex:1;-ms-flex:1 0 0px;flex:1 0 0}.rbc-time-slot.rbc-now{font-weight:700}.rbc-day-header{text-align:center}.rbc-slot-selection{z-index:10;position:absolute;background-color:#00000080;color:#fff;font-size:75%;width:100%;padding:3px}.rbc-slot-selecting{cursor:move}.rbc-time-view{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-flex:1;-ms-flex:1;flex:1;width:100%;border:1px solid #ddd;min-height:0}.rbc-time-view .rbc-time-gutter{white-space:nowrap;text-align:right}.rbc-time-view .rbc-allday-cell{-webkit-box-sizing:content-box;box-sizing:content-box;width:100%;height:100%;position:relative}.rbc-time-view .rbc-allday-cell+.rbc-allday-cell{border-left:1px solid #ddd}.rbc-time-view .rbc-allday-events{position:relative;z-index:4}.rbc-time-view .rbc-row{-webkit-box-sizing:border-box;box-sizing:border-box;min-height:20px}.rbc-time-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-ms-flex-direction:row;flex-direction:row}.rbc-time-header.rbc-overflowing{border-right:1px solid #ddd}.rbc-rtl .rbc-time-header.rbc-overflowing{border-right-width:0;border-left:1px solid #ddd}.rbc-time-header>.rbc-row:first-child{border-bottom:1px solid #ddd}.rbc-time-header>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd}.rbc-time-header-cell-single-day{display:none}.rbc-time-header-content{-webkit-box-flex:1;-ms-flex:1;flex:1;display:-webkit-box;display:-ms-flexbox;display:flex;min-width:0;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;border-left:1px solid #ddd}.rbc-rtl .rbc-time-header-content{border-left-width:0;border-right:1px solid #ddd}.rbc-time-header-content>.rbc-row.rbc-row-resource{border-bottom:1px solid #ddd;-ms-flex-negative:0;flex-shrink:0}.rbc-time-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-flex:1;-ms-flex:1 0 0%;flex:1 0 0%;-webkit-box-align:start;-ms-flex-align:start;align-items:flex-start;width:100%;border-top:2px solid #ddd;overflow-y:auto;position:relative}.rbc-time-content>.rbc-time-gutter{-webkit-box-flex:0;-ms-flex:none;flex:none}.rbc-time-content>*+*>*{border-left:1px solid #ddd}.rbc-rtl .rbc-time-content>*+*>*{border-left-width:0;border-right:1px solid #ddd}.rbc-time-content>.rbc-day-slot{width:100%;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-user-select:none}.rbc-current-time-indicator{position:absolute;z-index:3;left:0;right:0;height:1px;background-color:#74ad31;pointer-events:none}.rbc-resource-grouping.rbc-time-header-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column}.rbc-resource-grouping .rbc-row .rbc-header{width:141px}.calendar-page{padding:2rem;max-width:1600px;margin:0 auto;min-height:calc(100vh - 64px);display:flex;flex-direction:column;gap:1.5rem}.calendar-page__header{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem}.calendar-page__title{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.calendar-page__subtitle{font-size:1rem;color:var(--text-secondary);margin:.5rem 0 0}.calendar-page__frost{font-size:.9rem;color:#0ea5e9;margin:.25rem 0 0;font-weight:500}.calendar-page__garden-selector{display:inline-flex;align-items:center;gap:.5rem;background:var(--card-bg, #fff);border:1.5px solid var(--border-color, #e5e7eb);border-radius:var(--radius-lg, .75rem);padding:.4rem .75rem;margin:.5rem 0;transition:border-color var(--transition-base, .2s),box-shadow var(--transition-base, .2s)}.calendar-page__garden-selector:focus-within{border-color:var(--primary, #22c55e);box-shadow:0 0 0 3px #22c55e1a}.calendar-page__garden-selector label{font-size:.85rem;font-weight:600;color:var(--text-secondary);white-space:nowrap}.calendar-page__garden-selector select{border:none;background:transparent;font-size:.9rem;font-weight:600;color:var(--primary, #22c55e);cursor:pointer;font-family:inherit}.calendar-page__garden-selector select:focus{outline:none}@media(max-width:768px){.calendar-page__garden-selector{width:100%}.calendar-page__garden-selector select{flex:1}}.calendar-page__actions{display:flex;gap:.75rem;align-items:flex-start}.calendar-page__filters{background:var(--card-bg);border-radius:12px;padding:1rem 1.5rem;box-shadow:0 2px 8px #00000014;display:flex;flex-direction:column;gap:.75rem}.calendar-page__calendar{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;min-height:600px;overflow:hidden}.event-types{display:flex;flex-wrap:wrap;gap:1.5rem}.event-type{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;color:var(--text-primary)}.event-type__dot{width:12px;height:12px;border-radius:50%}.event-type--seeding .event-type__dot{background:#10b981}.event-type--transplant .event-type__dot{background:#3b82f6}.event-type--harvest .event-type__dot{background:#f59e0b}.event-type--irrigation .event-type__dot{background:#06b6d4}.event-type--fertilization .event-type__dot{background:#8b5cf6}.event-type-btn,.source-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:20px;border:1.5px solid var(--border-color, #ddd);background:transparent;font-size:.85rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s}.event-type-btn:hover,.source-btn:hover{border-color:var(--primary-color, #667eea);color:var(--primary-color, #667eea)}.event-type-btn--active,.source-btn--active{background:var(--primary-color, #667eea);border-color:var(--primary-color, #667eea);color:#fff}.event-type-btn--seeding .event-type__dot{background:#10b981}.event-type-btn--transplant .event-type__dot{background:#3b82f6}.event-type-btn--harvest .event-type__dot{background:#f59e0b}.event-type-btn--maintenance .event-type__dot{background:#6b7280}.event-type-btn--active .event-type__dot{background:#fff}.source-filters{display:flex;flex-wrap:wrap;gap:.5rem}.event-modal__body{padding:1.5rem}.event-modal__source{display:inline-block;padding:.25rem .75rem;border-radius:20px;background:#667eea1a;color:var(--primary-color, #667eea);font-size:.85rem;font-weight:500;margin-bottom:1rem}.event-modal__latin{color:var(--text-secondary);font-size:.95rem;margin-bottom:.5rem}.event-modal__dates{font-size:.9rem;color:var(--text-secondary);margin-bottom:1rem}.event-modal__tips{background:#10b98114;border-radius:8px;padding:1rem;margin-top:.5rem}.event-modal__tips h3{margin:0 0 .5rem;font-size:1rem;font-weight:600}.event-modal__tips ul{margin:0;padding-left:1.25rem}.event-modal__tips li{font-size:.9rem;color:var(--text-primary);margin-bottom:.3rem}.rbc-calendar{font-family:inherit}.rbc-calendar .rbc-header{padding:1rem .5rem;font-weight:600;color:var(--text-primary);border-bottom:2px solid rgba(102,126,234,.2)}.rbc-calendar .rbc-today{background-color:#667eea14}.rbc-calendar .rbc-off-range-bg{background:#00000005}.rbc-calendar .rbc-event{border-radius:6px;padding:2px 6px}.rbc-calendar .rbc-month-view{border-radius:8px;overflow:hidden}.rbc-calendar .rbc-day-bg{transition:background-color .2s ease}.rbc-calendar .rbc-day-bg:hover{background-color:#667eea0a}.rbc-calendar .rbc-toolbar{margin-bottom:1.5rem;padding:0 0 1rem;border-bottom:1px solid rgba(0,0,0,.1)}.rbc-calendar .rbc-toolbar button{padding:.5rem 1rem;border:1px solid rgba(102,126,234,.3);background:#fff;color:var(--text-primary);border-radius:6px;font-weight:500;transition:all .2s ease}.rbc-calendar .rbc-toolbar button:hover{background:#667eea1a;border-color:#667eea80}.rbc-calendar .rbc-toolbar button.rbc-active{background:#667eea;color:#fff;border-color:#667eea}.rbc-calendar .rbc-toolbar .rbc-toolbar-label{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.event-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:2rem}.event-modal{background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.event-modal__header{padding:1.5rem 2rem;border-bottom:1px solid rgba(0,0,0,.1);display:flex;justify-content:space-between;align-items:center}.event-modal__header h2{margin:0;font-size:1.5rem;font-weight:700;color:var(--text-primary)}.event-modal__close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.event-modal__close:hover{background:#0000000d;color:var(--text-primary)}.event-modal__form{padding:2rem}.event-modal__actions{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.1)}.event-modal__actions-right{display:flex;gap:.75rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.9rem;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.75rem 1rem;border:1px solid rgba(0,0,0,.2);border-radius:8px;font-size:1rem;font-family:inherit;transition:all .2s ease;background:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:100px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.calendar-page__timeline{background:var(--card-bg);border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #00000014;overflow-x:auto}.timeline-header__months{display:grid;grid-template-columns:140px repeat(12,minmax(48px,1fr));gap:2px;margin-bottom:.5rem;min-width:720px}.timeline-header__label{font-weight:600;font-size:.8rem;color:var(--text-secondary);padding:.5rem;position:sticky;left:0;z-index:2;background:var(--card-bg)}.timeline-header__month{text-align:center;font-weight:600;font-size:.75rem;color:var(--text-secondary);padding:.5rem .25rem;position:relative}.timeline-header__month--frost{color:#0ea5e9;font-weight:700}.frost-marker{display:block;font-size:.7rem;line-height:1}.timeline-body{display:flex;flex-direction:column;gap:2px}.timeline-row{display:grid;grid-template-columns:140px repeat(12,minmax(48px,1fr));gap:2px;align-items:center;min-height:36px;min-width:720px}.timeline-row--plan .timeline-row__label{font-weight:600}.timeline-row--companion{opacity:.75}.timeline-row--companion .timeline-row__label{font-style:italic}.timeline-row--catalog .timeline-row__label{font-weight:500}.timeline-row--category{grid-template-columns:1fr;background:#667eea14;border-radius:6px;min-height:30px;margin-top:.5rem}.timeline-row__category-label{font-size:.85rem;font-weight:700;color:var(--text-primary);padding:.3rem .5rem;letter-spacing:.02em;position:sticky;left:0}.timeline-row__label{font-size:.85rem;color:var(--text-primary);padding:.25rem .5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.35rem;position:sticky;left:0;z-index:1;background:var(--card-bg)}.timeline-row__source{font-size:.7rem}.timeline-row__source--plan,.timeline-row__source--seed{filter:none}.timeline-row__source--companion{filter:grayscale(.3)}.timeline-cell{height:28px;border-radius:4px;background:#00000005;display:flex;align-items:center;justify-content:center;gap:3px}.timeline-cell--active{background:#667eea0f}.timeline-dot{width:10px;height:10px;border-radius:50%;display:inline-block}.timeline-dot--seeding{background:#10b981}.timeline-dot--transplant{background:#3b82f6}.timeline-dot--harvest{background:#f59e0b}.timeline-dot--maintenance{background:#6b7280}.timeline-legend{display:flex;gap:1.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.08)}.timeline-legend__item{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary)}.timeline-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary);font-size:.95rem}@media(max-width:768px){.calendar-page{min-height:calc(100vh - var(--navbar-height));gap:1rem}.calendar-page__header{flex-direction:column;align-items:stretch;gap:1rem}.calendar-page__title{font-size:1.5rem}.calendar-page__filters,.calendar-page__calendar{padding:1rem}.event-types{gap:.75rem;font-size:.85rem}.calendar-page__timeline{padding:1rem .75rem}.timeline-header__months{grid-template-columns:110px repeat(12,minmax(38px,1fr));min-width:580px}.timeline-header__label{font-size:.7rem;padding:.35rem}.timeline-header__month{font-size:.65rem;padding:.35rem .15rem}.timeline-row{grid-template-columns:110px repeat(12,minmax(38px,1fr));min-width:580px;min-height:30px}.timeline-row__label{font-size:.75rem;padding:.2rem .35rem}.timeline-row__category-label{font-size:.8rem}.timeline-cell{height:24px}.timeline-dot{width:8px;height:8px}.timeline-legend{font-size:.75rem;gap:.75rem}.rbc-toolbar{flex-direction:column;gap:.75rem}.rbc-toolbar .rbc-toolbar-label{font-size:1rem}.rbc-toolbar button{padding:.4rem .75rem;font-size:.85rem}.event-modal-overlay{padding:1rem}.event-modal__header{padding:1rem 1.5rem}.event-modal__header h2{font-size:1.25rem}.event-modal__form{padding:1.5rem}.form-row{grid-template-columns:1fr}}.plant-catalog{padding:2rem;max-width:1400px;margin:0 auto}.plant-catalog .catalog-header{margin-bottom:2rem}.plant-catalog .catalog-header .header-content h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--primary-color, #2d6a4f)}.plant-catalog .catalog-header .header-content .subtitle{color:#666;font-size:1.1rem}.plant-catalog .catalog-filters{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.plant-catalog .catalog-filters .filter-group{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.plant-catalog .catalog-filters .filter-group:not(:last-child){margin-bottom:1rem}.plant-catalog .catalog-filters .search-input{flex:1;min-width:250px;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.plant-catalog .catalog-filters .search-input:focus{outline:none;border-color:var(--primary-color, #2d6a4f)}.plant-catalog .catalog-filters .filter-select{padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .3s}.plant-catalog .catalog-filters .filter-select:hover{border-color:#999}.plant-catalog .catalog-filters .filter-select:focus{outline:none;border-color:var(--primary-color, #2d6a4f)}.plant-catalog .catalog-filters .btn-clear-filters{padding:.75rem 1.5rem;background:#f44336;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem;transition:background .3s}.plant-catalog .catalog-filters .btn-clear-filters:hover{background:#d32f2f}.plant-catalog .catalog-results{margin-bottom:1rem}.plant-catalog .catalog-results .results-count{color:#666;font-size:.95rem}.plant-catalog .catalog-loading,.plant-catalog .catalog-error{text-align:center;padding:3rem}.plant-catalog .catalog-loading .spinner,.plant-catalog .catalog-error .spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--primary-color, #2d6a4f);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.plant-catalog .catalog-error{color:#f44336}.plant-catalog .plants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:2rem}.plant-catalog .plant-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .3s,box-shadow .3s}.plant-catalog .plant-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.plant-catalog .plant-card .plant-card-image{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);height:150px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}.plant-catalog .plant-card .plant-card-image .plant-icon-large{font-size:4rem}.plant-catalog .plant-card .plant-card-image .plant-icon-large--overlay{position:absolute;bottom:6px;right:8px;font-size:2rem;filter:drop-shadow(0 1px 3px rgba(0,0,0,.4));z-index:1}.plant-catalog .plant-card .plant-card-image--photo{background:#f0f0f0}.plant-catalog .plant-card .plant-card-image .plant-card-photo{width:100%;height:100%;object-fit:cover;transition:transform .3s}.plant-catalog .plant-card:hover .plant-card-photo{transform:scale(1.05)}.plant-catalog .plant-card .plant-card-content{padding:1.25rem}.plant-catalog .plant-card .plant-card-content .plant-name{font-size:1.25rem;margin:0 0 .5rem;color:#333}.plant-catalog .plant-card .plant-card-content .plant-latin{font-size:.9rem;color:#666;font-style:italic;margin:0 0 1rem}.plant-catalog .plant-card .plant-card-content .plant-badges{margin-bottom:1rem;display:flex;flex-wrap:wrap;gap:.35rem}.plant-catalog .plant-card .plant-card-content .plant-badges .badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:500}.plant-catalog .plant-card .plant-card-content .plant-badges .badge-family{background:#e3f2fd;color:#1976d2}.plant-catalog .plant-card .plant-card-content .plant-badges .badge-ornamental{background:#fce4ec;color:#c62828}.plant-catalog .plant-card .plant-card-content .plant-badges .badge-perennial{background:#e8f5e9;color:#2e7d32}.plant-catalog .plant-card .plant-card-content .plant-badges .badge-seasonal{background:#fff3e0;color:#e65100}.plant-catalog .plant-card .plant-card-content .plant-info-icons{display:flex;gap:.75rem;font-size:1.5rem}.plant-catalog .plant-card .plant-card-content .plant-info-icons .info-icon{cursor:help}.plant-catalog .no-results{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.plant-catalog .modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.plant-catalog .modal-content{background:#fff;border-radius:16px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 8px 32px #0000004d}.plant-catalog .modal-close{position:absolute;top:1rem;right:1rem;background:#0000001a;border:none;border-radius:50%;width:36px;height:36px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s;z-index:1}.plant-catalog .modal-close:hover{background:#0003}.plant-catalog .modal-header{background:linear-gradient(135deg,#2e7d32,#388e3c,#43a047);padding:0;position:relative;min-height:120px;border-radius:12px 12px 0 0;overflow:hidden}.plant-catalog .modal-header--hero{min-height:180px;background-size:cover;background-position:center}.plant-catalog .modal-header .modal-header-overlay{display:flex;gap:1.5rem;align-items:center;padding:2rem;background:linear-gradient(to top,#0009,#0000001a);min-height:inherit}.plant-catalog .modal-header--hero h2,.plant-catalog .modal-header--hero .modal-latin,.plant-catalog .modal-header--hero .modal-alt-names{color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5)}.plant-catalog .modal-header--hero .modal-icon .plant-icon-xl{filter:drop-shadow(0 2px 4px rgba(0,0,0,.4))}.plant-catalog .modal-header .modal-icon .plant-icon-xl{font-size:5rem}.plant-catalog .modal-header h2{margin:0 0 .5rem;color:#fff;font-size:1.8rem;text-shadow:0 1px 3px rgba(0,0,0,.3)}.plant-catalog .modal-header .modal-latin{font-style:italic;color:#ffffffe6;font-size:1.1rem;margin:0;text-shadow:0 1px 3px rgba(0,0,0,.3)}.plant-catalog .modal-header .modal-alt-names{font-size:.9rem;color:#fffc;margin:.5rem 0 0;text-shadow:0 1px 3px rgba(0,0,0,.3)}.plant-catalog .modal-body{padding:2rem}.plant-catalog .modal-body .info-section{margin-bottom:2rem}.plant-catalog .modal-body .info-section:last-child{margin-bottom:0}.plant-catalog .modal-body .info-section h3{margin:0 0 1rem;color:var(--primary-color, #2d6a4f);font-size:1.2rem}.plant-catalog .modal-body .info-section .info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.plant-catalog .modal-body .info-section .info-item{background:#f5f5f5;padding:.75rem 1rem;border-radius:8px}.plant-catalog .modal-body .info-section .info-item strong{display:block;color:#666;font-size:.85rem;margin-bottom:.25rem}.plant-catalog .modal-body .info-section .tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.plant-catalog .modal-body .info-section .tags-list .tag{padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:500}.plant-catalog .modal-body .info-section .tags-list .tag-good{background:#e8f5e9;color:#2e7d32}.plant-catalog .modal-body .info-section .tags-list .tag-bad{background:#ffebee;color:#c62828}@media(min-width:769px)and (max-width:1024px){.plant-catalog{padding:1.5rem}.plant-catalog .plants-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}@media(max-width:768px){.plant-catalog{padding:1rem}.plant-catalog .catalog-header .header-content h1{font-size:2rem}.plant-catalog .catalog-filters{padding:1rem}.plant-catalog .catalog-filters .filter-group{flex-direction:column}.plant-catalog .catalog-filters .filter-group .search-input,.plant-catalog .catalog-filters .filter-group .filter-select{width:100%}.plant-catalog .plants-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.plant-catalog .modal-header .modal-header-overlay{flex-direction:column;text-align:center}.plant-catalog .modal-header h2{font-size:1.5rem}.plant-catalog .modal-body{padding:1rem}.plant-catalog .modal-body .info-section .info-grid{grid-template-columns:1fr}}@media(max-width:480px){.plant-catalog{padding:.75rem}.plant-catalog .plants-grid{grid-template-columns:1fr}.plant-catalog .plant-card .plant-card-content .plant-name{font-size:1rem}}.plant-catalog .of-loading{display:flex;align-items:center;gap:.75rem;color:#888;font-size:.95rem;margin-bottom:1rem}.plant-catalog .of-spinner{display:inline-block;width:18px;height:18px;border:2px solid #e0e0e0;border-top-color:#66bb6a;border-radius:50%;animation:spin .8s linear infinite}.plant-catalog .of-description{color:#444;line-height:1.7;margin:0;font-size:.95rem}.plant-catalog .of-badge{display:inline-block;background:#e8f5e9;color:#2e7d32;font-size:.7rem;padding:.15rem .5rem;border-radius:10px;font-weight:600;vertical-align:middle;margin-left:.4rem}.plant-catalog .modal-photo{width:90px;height:90px;border-radius:50%;overflow:hidden;flex-shrink:0}.plant-catalog .modal-photo img{width:100%;height:100%;object-fit:cover}.plant-catalog .modal-actions{margin-top:1.5rem;text-align:center}.plant-catalog .modal-actions .btn-detail{padding:.85rem 2rem;background:var(--primary-color, #2d6a4f);color:#fff;border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;transition:background .3s,transform .2s}.plant-catalog .modal-actions .btn-detail:hover{background:#1b5e3b;transform:translateY(-1px)}.plant-detail{min-height:100vh;background:#f8f9fa}.plant-detail .pd-loading,.plant-detail .pd-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem;color:#666}.plant-detail .pd-spinner{display:inline-block;width:24px;height:24px;border:3px solid #e0e0e0;border-top-color:var(--primary-color, #2d6a4f);border-radius:50%;animation:pd-spin .8s linear infinite}@keyframes pd-spin{to{transform:rotate(360deg)}}.plant-detail .btn-back{padding:.75rem 1.5rem;background:var(--primary-color, #2d6a4f);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1rem}.plant-detail .pd-hero{position:relative;min-height:260px;background-size:cover;background-position:center;background-color:linear-gradient(135deg,#e8f5e9 0%,#a5d6a7 100%);background-image:linear-gradient(135deg,#e8f5e9,#a5d6a7)}.plant-detail .pd-hero-overlay{min-height:260px;background:linear-gradient(to bottom,#0000001a,#0000008c);padding:1.5rem 2rem 2rem;display:flex;flex-direction:column;justify-content:space-between}.plant-detail .btn-back-hero{background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:8px;cursor:pointer;font-size:.95rem;width:fit-content;transition:background .3s}.plant-detail .btn-back-hero:hover{background:#ffffff59}.plant-detail .pd-hero-content{display:flex;align-items:center;gap:1.25rem;color:#fff}.plant-detail .pd-hero-content h1{margin:0;font-size:2.2rem;text-shadow:0 2px 8px rgba(0,0,0,.3)}.plant-detail .pd-hero-content .pd-hero-emoji{font-size:4rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.plant-detail .pd-hero-content .pd-hero-latin{margin:.25rem 0;font-style:italic;opacity:.9;font-size:1.1rem}.plant-detail .pd-hero-content .pd-hero-family{display:inline-block;margin-top:.4rem;background:#fff3;padding:.2rem .75rem;border-radius:20px;font-size:.9rem}.plant-detail .pd-stats{display:flex;gap:0;background:#fff;border-bottom:1px solid #e8e8e8;overflow-x:auto;-webkit-overflow-scrolling:touch}.plant-detail .pd-stat{flex:1;min-width:100px;display:flex;flex-direction:column;align-items:center;padding:1rem .75rem;gap:.3rem;border-right:1px solid #f0f0f0}.plant-detail .pd-stat:last-child{border-right:none}.plant-detail .pd-stat .pd-stat-icon{font-size:1.5rem}.plant-detail .pd-stat .pd-stat-label{font-size:.8rem;color:#666;text-align:center;white-space:nowrap}.plant-detail .pd-tabs{display:flex;background:#fff;border-bottom:2px solid #e8e8e8;overflow-x:auto;-webkit-overflow-scrolling:touch}.plant-detail .pd-tab{flex:1;padding:.85rem 1rem;border:none;background:none;font-size:.95rem;color:#666;cursor:pointer;white-space:nowrap;border-bottom:3px solid transparent;transition:all .2s}.plant-detail .pd-tab:hover{color:var(--primary-color, #2d6a4f);background:#f8fdf8}.plant-detail .pd-tab--active{color:var(--primary-color, #2d6a4f);border-bottom-color:var(--primary-color, #2d6a4f);font-weight:600}.plant-detail .pd-content{max-width:960px;margin:0 auto;padding:1.5rem 2rem 3rem}.plant-detail .of-loading{display:flex;align-items:center;gap:.75rem;color:#888;font-size:.95rem;margin-bottom:1rem}.plant-detail .of-spinner{display:inline-block;width:18px;height:18px;border:2px solid #e0e0e0;border-top-color:#66bb6a;border-radius:50%;animation:pd-spin .8s linear infinite}.plant-detail .of-badge{display:inline-block;background:#e8f5e9;color:#2e7d32;font-size:.7rem;padding:.15rem .5rem;border-radius:10px;font-weight:600;vertical-align:middle;margin-left:.4rem}.plant-detail .of-dot{display:inline-block;width:6px;height:6px;background:#66bb6a;border-radius:50%;margin-left:4px;vertical-align:middle}.plant-detail .pd-section{margin-bottom:2rem}.plant-detail .pd-section h3{margin:0 0 1rem;font-size:1.2rem;color:var(--primary-color, #2d6a4f)}.plant-detail .pd-text{color:#444;line-height:1.7;font-size:1rem}.plant-detail .pd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.plant-detail .pd-info-card{background:#fff;border:1px solid #e8e8e8;border-radius:10px;padding:.85rem 1rem;display:flex;flex-direction:column;gap:.3rem;transition:box-shadow .2s}.plant-detail .pd-info-card:hover{box-shadow:0 2px 8px #00000014}.plant-detail .pd-info-card--of{border-left:3px solid #66bb6a}.plant-detail .pd-info-card .pd-info-label{font-size:.78rem;color:#888;text-transform:uppercase;letter-spacing:.5px;font-weight:600}.plant-detail .pd-info-card .pd-info-value{font-size:1rem;color:#333}.plant-detail .pd-tags{display:flex;flex-wrap:wrap;gap:.5rem}.plant-detail .pd-tag{padding:.4rem .9rem;border-radius:20px;font-size:.9rem;font-weight:500;background:#f0f0f0;color:#555}.plant-detail .pd-tag--good{background:#e8f5e9;color:#2e7d32}.plant-detail .pd-tag--bad{background:#ffebee;color:#c62828}.plant-detail .pd-stages{display:flex;flex-direction:column;gap:1rem}.plant-detail .pd-stage{display:flex;gap:1rem;align-items:flex-start}.plant-detail .pd-stage-num{min-width:36px;height:36px;border-radius:50%;background:var(--primary-color, #2d6a4f);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.95rem;flex-shrink:0}.plant-detail .pd-stage-body{flex:1}.plant-detail .pd-stage-body h4{margin:0 0 .3rem;color:#333;font-size:1.05rem}.plant-detail .pd-stage-body p{margin:0;color:#555;line-height:1.6;font-size:.95rem}.plant-detail .pd-tips{display:flex;flex-direction:column;gap:1rem}.plant-detail .pd-tip{display:flex;gap:1rem;background:#fff;border:1px solid #e8e8e8;border-radius:12px;padding:1.25rem}.plant-detail .pd-tip .pd-tip-icon{font-size:2rem;flex-shrink:0}.plant-detail .pd-tip h4{margin:0 0 .4rem;color:#333;font-size:1.05rem}.plant-detail .pd-tip p{margin:0;color:#555;line-height:1.6;font-size:.95rem}.plant-detail .pd-companion-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.plant-detail .pd-companion-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;background:#fff;border:1px solid #e8e8e8;border-radius:10px;padding:.75rem;text-align:center;font-size:.9rem;color:#444}.plant-detail .pd-companion-img{width:60px;height:60px;border-radius:50%;object-fit:cover}.plant-detail .pd-companion-placeholder{width:60px;height:60px;border-radius:50%;background:#e8f5e9;display:flex;align-items:center;justify-content:center;font-size:1.5rem}@media(max-width:768px){.plant-detail .pd-hero{min-height:200px}.plant-detail .pd-hero-overlay{min-height:200px;padding:1rem}.plant-detail .pd-hero-content h1{font-size:1.5rem}.plant-detail .pd-hero-content .pd-hero-emoji{font-size:3rem}.plant-detail .pd-content{padding:1rem}.plant-detail .pd-grid{grid-template-columns:1fr 1fr}.plant-detail .pd-tab{font-size:.85rem;padding:.75rem .5rem}}@media(max-width:480px){.plant-detail .pd-grid{grid-template-columns:1fr}.plant-detail .pd-companion-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}}.seed-box{padding:2rem;max-width:1400px;margin:0 auto}.seed-box .seed-box-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.seed-box .seed-box-header .header-content h1{font-size:2.5rem;margin:0 0 .5rem;color:var(--primary-color, #2d6a4f)}.seed-box .seed-box-header .header-content .subtitle{color:#666;font-size:1.1rem;margin:0}.seed-box .seed-box-header .header-content .subtitle .subtitle-warning{color:#e67e22;font-weight:600}.seed-box .seed-box-header .btn-primary{padding:.75rem 1.5rem;background:var(--primary-color, #2d6a4f);color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .3s}.seed-box .seed-box-header .btn-primary:hover{background:#1b5e3f}.seed-box .expiring-alert{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:2px solid #ffc107;border-radius:12px;padding:1rem 1.5rem;margin-bottom:2rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #ffc10733}.seed-box .expiring-alert .alert-icon{font-size:1.5rem}.seed-box .expiring-alert span{flex:1;font-weight:500;color:#856404}.seed-box .expiring-alert .btn-alert{padding:.5rem 1rem;background:#ffc107;color:#856404;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .3s}.seed-box .expiring-alert .btn-alert:hover{background:#ffb300}.seed-box .seed-box-filters{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;display:flex;align-items:center;gap:1rem}.seed-box .seed-box-filters .search-input{flex:1;min-width:0;padding:.75rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.seed-box .seed-box-filters .search-input:focus{outline:none;border-color:var(--primary-color, #2d6a4f)}.seed-box .seed-box-filters .filter-buttons{display:flex;gap:.5rem;flex-shrink:0}.seed-box .seed-box-filters .filter-buttons .filter-btn{padding:.5rem 1rem;background:#f5f5f5;color:#666;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .3s;font-weight:500}.seed-box .seed-box-filters .filter-buttons .filter-btn:hover{background:#e0e0e0}.seed-box .seed-box-filters .filter-buttons .filter-btn.active{background:var(--primary-color, #2d6a4f);color:#fff;border-color:var(--primary-color, #2d6a4f)}.seed-box .seed-box-loading,.seed-box .seed-box-error{text-align:center;padding:3rem}.seed-box .seed-box-loading .spinner,.seed-box .seed-box-error .spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--primary-color, #2d6a4f);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.seed-box .seed-box-error{color:#f44336}.seed-box .packets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:2rem}.seed-box .packet-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;transition:transform .3s,box-shadow .3s;position:relative}.seed-box .packet-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.seed-box .packet-card.expiring{border:2px solid #ffc107;background:linear-gradient(to bottom,#fffbf0,#fff)}.seed-box .packet-card .expiring-badge{position:absolute;top:.5rem;right:.5rem;background:#ffc107;color:#856404;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.seed-box .packet-card .packet-header{display:flex;gap:1rem;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.seed-box .packet-card .packet-header .packet-icon{font-size:2.5rem;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center}.seed-box .packet-card .packet-header .packet-title{flex:1}.seed-box .packet-card .packet-header .packet-title h3{margin:0 0 .25rem;font-size:1.2rem;color:#333}.seed-box .packet-card .packet-header .packet-title .variety-name{margin:0;color:#666;font-size:.95rem;font-style:italic}.seed-box .packet-card .packet-info{margin-bottom:1.25rem}.seed-box .packet-card .packet-info .info-row{display:flex;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid #f5f5f5}.seed-box .packet-card .packet-info .info-row:last-child{border-bottom:none}.seed-box .packet-card .packet-info .info-row.notes{flex-direction:column}.seed-box .packet-card .packet-info .info-row.notes .value{margin-top:.5rem;font-size:.9rem;color:#666;font-style:italic}.seed-box .packet-card .packet-info .info-row .label{color:#999;font-size:.9rem}.seed-box .packet-card .packet-info .info-row .value{color:#333;font-weight:500}.seed-box .packet-card .packet-info .info-row .value.expiring-text{color:#f57c00;font-weight:600}.seed-box .packet-card .packet-actions{display:flex;gap:.5rem}.seed-box .packet-card .packet-actions button{flex:1;padding:.625rem;border:none;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .3s;font-weight:500}.seed-box .packet-card .packet-actions .btn-edit{background:#e3f2fd;color:#1976d2}.seed-box .packet-card .packet-actions .btn-edit:hover{background:#bbdefb}.seed-box .packet-card .packet-actions .btn-delete{background:#ffebee;color:#c62828}.seed-box .packet-card .packet-actions .btn-delete:hover{background:#ffcdd2}.seed-box .no-packets{text-align:center;padding:3rem;color:#666}.seed-box .no-packets p{margin:.5rem 0}.seed-box .no-packets .hint{font-size:.9rem;color:#999}.seed-box .modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.seed-box .modal-content.seed-modal{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 8px 32px #0000004d;padding:2rem}.seed-box .modal-content.seed-modal h2{margin:0 0 1.5rem;color:var(--primary-color, #2d6a4f);font-size:1.8rem}.seed-box .modal-content.seed-modal .form-section{margin-bottom:2rem}.seed-box .modal-content.seed-modal .form-section h3{margin:0 0 1rem;color:#666;font-size:1.1rem;padding-bottom:.5rem;border-bottom:2px solid #f0f0f0}.seed-box .modal-content.seed-modal .form-group{margin-bottom:1.25rem}.seed-box .modal-content.seed-modal .form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.seed-box .modal-content.seed-modal .form-group input,.seed-box .modal-content.seed-modal .form-group select,.seed-box .modal-content.seed-modal .form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s}.seed-box .modal-content.seed-modal .form-group input:focus,.seed-box .modal-content.seed-modal .form-group select:focus,.seed-box .modal-content.seed-modal .form-group textarea:focus{outline:none;border-color:var(--primary-color, #2d6a4f)}.seed-box .modal-content.seed-modal .form-group textarea{resize:vertical;font-family:inherit}.seed-box .modal-content.seed-modal .form-group small{display:block;margin-top:.5rem;color:#999;font-size:.85rem}.seed-box .modal-content.seed-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.seed-box .modal-content.seed-modal .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:2px solid #f0f0f0}.seed-box .modal-content.seed-modal .form-actions button{padding:.75rem 2rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s;font-weight:500}.seed-box .modal-content.seed-modal .form-actions .btn-secondary{background:#f5f5f5;color:#666}.seed-box .modal-content.seed-modal .form-actions .btn-secondary:hover{background:#e0e0e0}.seed-box .modal-content.seed-modal .form-actions .btn-primary{background:var(--primary-color, #2d6a4f);color:#fff}.seed-box .modal-content.seed-modal .form-actions .btn-primary:hover{background:#1b5e3f}.seed-box .modal-close{position:absolute;top:1rem;right:1rem;background:#0000001a;border:none;border-radius:50%;width:36px;height:36px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s}.seed-box .modal-close:hover{background:#0003}@media(min-width:769px)and (max-width:1024px){.seed-box{padding:1.5rem}.seed-box .packets-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.seed-box{padding:1rem}.seed-box .seed-box-header{flex-direction:column;align-items:flex-start;gap:1rem}.seed-box .seed-box-header .header-content h1{font-size:2rem}.seed-box .seed-box-header .btn-primary{width:100%}.seed-box .seed-box-filters{flex-direction:column}.seed-box .seed-box-filters .search-input{width:100%}.seed-box .packets-grid{grid-template-columns:1fr}.seed-box .modal-content.seed-modal{padding:1.5rem}.seed-box .modal-content.seed-modal .form-row{grid-template-columns:1fr}.seed-box .modal-content.seed-modal .form-actions{flex-direction:column}.seed-box .modal-content.seed-modal .form-actions button{width:100%}}@media(max-width:480px){.seed-box{padding:.75rem}.seed-box .seed-box-header .header-content h1{font-size:1.5rem}.seed-box .packet-card{padding:.75rem}}.observations{max-width:800px;margin:0 auto;padding:2rem}.observations .obs-header{text-align:center;margin-bottom:2.5rem}.observations .obs-header h1{font-size:2.2rem;color:var(--primary-color, #2d6a4f);margin:0 0 .5rem}.observations .obs-header .obs-subtitle{color:#666;font-size:1.05rem;margin:0}.observations .obs-modes{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.observations .obs-mode-card{background:#fff;border:2px solid #e8e8e8;border-radius:16px;padding:2rem 1.5rem;text-align:center;cursor:pointer;transition:all .3s}.observations .obs-mode-card:hover{border-color:var(--primary-color, #2d6a4f);box-shadow:0 4px 16px #2d6a4f26;transform:translateY(-2px)}.observations .obs-mode-card .obs-mode-icon{font-size:3rem;display:block;margin-bottom:1rem}.observations .obs-mode-card h3{margin:0 0 .5rem;color:#333;font-size:1.2rem}.observations .obs-mode-card p{margin:0;color:#666;font-size:.9rem;line-height:1.5}.observations .obs-capture{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 12px #00000014}.observations .obs-capture-header,.observations .obs-results-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.observations .obs-capture-header h2,.observations .obs-results-header h2{margin:0;font-size:1.4rem;color:#333}.observations .btn-back-obs{background:none;border:1px solid #ddd;border-radius:8px;padding:.5rem 1rem;cursor:pointer;font-size:.9rem;color:#555;transition:all .2s}.observations .btn-back-obs:hover{background:#f5f5f5;border-color:#bbb}.observations .obs-camera{position:relative;border-radius:12px;overflow:hidden;margin-bottom:1rem;background:#000}.observations .obs-video{width:100%;min-height:240px;object-fit:cover;display:block;border-radius:12px;background:#000}.observations .btn-capture{position:absolute;bottom:1.5rem;left:50%;transform:translate(-50%);background:#fff;border:3px solid var(--primary-color, #2d6a4f);border-radius:50px;padding:.75rem 2rem;font-size:1.1rem;cursor:pointer;font-weight:600;box-shadow:0 4px 16px #0000004d;transition:all .2s}.observations .btn-capture:hover{background:var(--primary-color, #2d6a4f);color:#fff}.observations .obs-preview{text-align:center;margin-bottom:1.5rem}.observations .obs-preview-img{max-width:100%;max-height:400px;border-radius:12px;object-fit:contain;box-shadow:0 2px 12px #0000001a}.observations .obs-actions{display:flex;flex-direction:column;gap:.75rem;align-items:center}.observations .obs-file-input{display:none}.observations .btn-obs{padding:.85rem 2rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:.5rem;min-width:260px;justify-content:center}.observations .btn-obs--primary{background:var(--primary-color, #2d6a4f);color:#fff}.observations .btn-obs--primary:hover{background:#1b5e3b}.observations .btn-obs--primary:disabled{opacity:.7;cursor:not-allowed}.observations .btn-obs--secondary{background:#f0f0f0;color:#555}.observations .btn-obs--secondary:hover{background:#e0e0e0}.observations .obs-spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:obs-spin .8s linear infinite}@keyframes obs-spin{to{transform:rotate(360deg)}}.observations .obs-error{margin-top:1rem;padding:1rem;background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;font-size:.95rem}.observations .obs-results{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 2px 12px #00000014}.observations .obs-result-img{text-align:center;margin-bottom:1.5rem}.observations .obs-result-img img{max-width:100%;max-height:300px;border-radius:12px;object-fit:contain}.observations .obs-no-result{text-align:center;color:#888;padding:2rem;font-size:1.1rem}.observations .obs-health-status{display:flex;align-items:center;gap:1rem;padding:1.25rem;border-radius:12px;margin-bottom:1.5rem}.observations .obs-health-status .obs-health-icon{font-size:2.5rem}.observations .obs-health-status h3{margin:0 0 .25rem;font-size:1.2rem}.observations .obs-health-status p{margin:0;color:#666;font-size:.95rem}.observations .obs-health-status--ok{background:#f0fff4;border:1px solid #c6f6d5}.observations .obs-health-status--bad{background:#fffaf0;border:1px solid #feebc8}.observations .obs-diseases h3,.observations .obs-crop-id h3,.observations .obs-plantnet-results h3{margin:0 0 1rem;color:#333;font-size:1.2rem}.observations .obs-disease-card,.observations .obs-identify-card,.observations .obs-crop-card,.observations .obs-plantnet-card{background:#fafafa;border:1px solid #e8e8e8;border-radius:12px;padding:1.25rem;margin-bottom:1rem}.observations .obs-disease-card--best,.observations .obs-identify-card--best,.observations .obs-crop-card--best,.observations .obs-plantnet-card--best{border-color:var(--primary-color, #2d6a4f);border-width:2px;background:#f0fff4}.observations .obs-disease-header,.observations .obs-identify-header,.observations .obs-crop-header,.observations .obs-plantnet-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.observations .obs-disease-header h4,.observations .obs-identify-header h4,.observations .obs-crop-header h4,.observations .obs-plantnet-header h4{margin:0;font-size:1.1rem;color:#333}.observations .obs-disease-prob,.observations .obs-identify-prob,.observations .obs-crop-prob,.observations .obs-plantnet-score{background:var(--primary-color, #2d6a4f);color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;flex-shrink:0}.observations .obs-disease-desc,.observations .obs-identify-desc{color:#555;line-height:1.6;font-size:.95rem;margin:0 0 1rem}.observations .obs-identify-common,.observations .obs-crop-common,.observations .obs-plantnet-common{color:#888;font-style:italic;font-size:.9rem;margin:.25rem 0 0}.observations .obs-crop-latin,.observations .obs-disease-latin,.observations .obs-plantnet-latin{color:#777;font-size:.85rem;margin:.15rem 0 0}.observations .obs-plantnet-family,.observations .obs-plantnet-genus{color:#888;font-size:.85rem;margin:.1rem 0 0}.observations .obs-disease-common{color:#888;font-style:italic;font-size:.9rem;margin:.15rem 0 0}.observations .obs-best-match{background:#e8f5e9;border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;font-size:.95rem;color:#2d6a4f}.observations .obs-diagnosis-cta{text-align:center;margin:1.5rem 0}.observations .obs-diagnosis-cta .btn-obs--warning{background:#ed8936;color:#fff;border:none;padding:.85rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s}.observations .obs-diagnosis-cta .btn-obs--warning:hover{background:#dd6b20}.observations .obs-diagnosis-cta .btn-obs--warning:disabled{opacity:.6;cursor:wait}.observations .obs-healthy-msg{background:#f0fff4;border:1px solid #c6f6d5;border-radius:12px;padding:1.25rem;text-align:center;color:#2d6a4f;font-size:1rem}.observations .obs-crop-results{display:flex;flex-direction:column;gap:1.5rem}.observations .obs-symptoms,.observations .obs-severity,.observations .obs-spreading{margin-top:.5rem;font-size:.92rem;color:#555;line-height:1.6}.observations .obs-symptoms strong,.observations .obs-severity strong,.observations .obs-spreading strong{color:#444}.observations .obs-treatment{margin-top:.75rem}.observations .obs-treatment h5{margin:0 0 .5rem;font-size:.95rem;color:#444}.observations .obs-treatment ul{margin:0;padding-left:1.5rem}.observations .obs-treatment ul li{color:#555;line-height:1.6;font-size:.9rem;margin-bottom:.25rem}.observations .obs-similar{margin-top:1rem}.observations .obs-similar h5{margin:0 0 .5rem;font-size:.9rem;color:#666}.observations .obs-similar-grid{display:flex;gap:.5rem;overflow-x:auto}.observations .obs-similar-img{width:100px;height:100px;border-radius:8px;object-fit:cover;flex-shrink:0}.observations .obs-history{margin-top:2.5rem}.observations .obs-history h2{margin:0 0 1rem;font-size:1.3rem;color:#333}.observations .obs-history-list{display:flex;flex-direction:column;gap:.5rem}.observations .obs-history-item{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e8e8e8;border-radius:10px;padding:.85rem 1rem}.observations .obs-history-item .obs-history-icon{font-size:1.5rem}.observations .obs-history-item .obs-history-info{display:flex;flex-direction:column}.observations .obs-history-item .obs-history-info strong{font-size:.95rem;color:#333}.observations .obs-history-item .obs-history-info .obs-history-date{font-size:.8rem;color:#999;margin-top:.15rem}@media(max-width:768px){.observations{padding:1rem}.observations .obs-header h1{font-size:1.6rem}.observations .obs-modes{grid-template-columns:1fr;gap:1rem}.observations .obs-mode-card{padding:1.5rem 1rem}.observations .obs-capture,.observations .obs-results{padding:1.25rem}.observations .btn-obs{min-width:100%}.observations .obs-similar-img{width:80px;height:80px}}@media(max-width:480px){.observations{padding:.75rem}.observations .obs-mode-card .obs-mode-icon{font-size:2rem}}.community{max-width:900px;margin:0 auto;padding:1.5rem 1rem}.community__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;gap:1rem;color:var(--text-secondary, #666)}.community__header{text-align:center;margin-bottom:1.5rem}.community__header h1{margin:0 0 .25rem;font-size:1.5rem}.community__header p{color:var(--text-secondary, #666);margin:0;font-size:.9rem}.community__tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border, #e0e0e0);margin-bottom:1.5rem;overflow-x:auto}.community__tab{padding:.6rem 1.2rem;border:none;background:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--text-secondary, #666);border-bottom:3px solid transparent;transition:all .2s;white-space:nowrap;position:relative}.community__tab:hover{color:var(--text-primary, #333)}.community__tab--active{color:var(--primary, #4caf50);border-bottom-color:var(--primary, #4caf50)}.community__badge{position:absolute;top:2px;right:-4px;background:#e53935;color:#fff;font-size:.7rem;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center}.post-feed__filters{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.post-feed__filter{padding:.4rem .8rem;border:1px solid var(--border, #ddd);border-radius:20px;background:var(--bg-card, #fff);cursor:pointer;font-size:.8rem;transition:all .2s}.post-feed__filter:hover{background:var(--bg-hover, #f5f5f5)}.post-feed__filter--active{background:var(--primary, #4caf50);color:#fff;border-color:var(--primary, #4caf50)}.post-feed__new-btn,.post-feed__load-more{width:100%;padding:.7rem;border:2px dashed var(--primary, #4caf50);border-radius:8px;background:transparent;color:var(--primary, #4caf50);cursor:pointer;font-weight:600;margin-bottom:1rem;transition:all .2s}.post-feed__new-btn:hover,.post-feed__load-more:hover{background:var(--primary, #4caf50);color:#fff}.post-feed__form{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:10px;padding:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.6rem}.post-feed__form input,.post-feed__form textarea,.post-feed__form select{padding:.5rem;border:1px solid var(--border, #ddd);border-radius:6px;font-size:.9rem;background:var(--bg-input, #fafafa);color:var(--text-primary, #333)}.post-feed__form input:focus,.post-feed__form textarea:focus,.post-feed__form select:focus{outline:none;border-color:var(--primary, #4caf50)}.post-feed__form-row{display:flex;gap:.5rem}.post-feed__submit{padding:.5rem 1rem;background:var(--primary, #4caf50);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.post-feed__loading,.post-feed__empty{text-align:center;color:var(--text-secondary, #888);padding:2rem}.post-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:10px;padding:1rem;margin-bottom:.75rem;cursor:pointer;transition:box-shadow .2s}.post-card:hover{box-shadow:0 2px 8px #00000014}.post-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.post-card__author{display:flex;align-items:center;gap:.5rem}.post-card__avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.post-card__avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--primary, #4caf50);color:#fff;font-weight:600;font-size:.8rem}.post-card__username{font-weight:500;font-size:.85rem;cursor:pointer}.post-card__username:hover{text-decoration:underline}.post-card__type{color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.post-card__title{font-size:1.05rem;margin:0 0 .3rem;display:flex;align-items:center;gap:.5rem}.post-card__resolved{font-size:.8rem}.post-card__content{color:var(--text-secondary, #555);font-size:.9rem;margin:0 0 .5rem;line-height:1.4}.post-card__garden{font-size:.8rem;color:var(--text-secondary, #777);margin-bottom:.4rem}.post-card__tags{display:flex;gap:.3rem;flex-wrap:wrap;margin-bottom:.4rem}.post-card__tag{background:var(--bg-hover, #f0f0f0);padding:.15rem .5rem;border-radius:10px;font-size:.75rem;color:var(--text-secondary, #555)}.post-card__footer{display:flex;align-items:center;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border, #eee)}.post-card__action{background:none;border:none;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:.2rem;color:var(--text-secondary, #666)}.post-card__action--liked,.post-card__action--delete:hover{color:#e53935}.post-card__date{margin-left:auto;font-size:.75rem;color:var(--text-secondary, #999)}.post-detail__back{background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--primary, #4caf50);margin-bottom:1rem;padding:0}.post-detail__back:hover{text-decoration:underline}.post-detail__article{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:10px;padding:1.25rem;margin-bottom:1.5rem}.post-detail__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.post-detail__date{font-size:.8rem;color:var(--text-secondary, #999)}.post-detail__title{font-size:1.25rem;margin:0 0 .75rem}.post-detail__body{white-space:pre-wrap;line-height:1.6;margin-bottom:1rem;color:var(--text-primary, #333)}.post-detail__actions{display:flex;align-items:center;gap:1rem;padding-top:.75rem;border-top:1px solid var(--border, #eee)}.post-detail__resolve-btn{background:none;border:1px solid var(--primary, #4caf50);color:var(--primary, #4caf50);padding:.3rem .7rem;border-radius:6px;cursor:pointer;font-size:.8rem}.post-detail__resolve-btn:hover{background:var(--primary, #4caf50);color:#fff}.post-detail__comments h3{margin-bottom:1rem}.post-detail__comment-form{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:8px;padding:.75rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.post-detail__comment-form textarea{padding:.5rem;border:1px solid var(--border, #ddd);border-radius:6px;resize:vertical;background:var(--bg-input, #fafafa);color:var(--text-primary, #333)}.post-detail__comment-form button{align-self:flex-end;padding:.4rem 1rem;background:var(--primary, #4caf50);color:#fff;border:none;border-radius:6px;cursor:pointer}.post-detail__reply-to{display:flex;justify-content:space-between;align-items:center;background:var(--bg-hover, #f5f5f5);padding:.4rem .6rem;border-radius:6px;font-size:.85rem}.post-detail__reply-to button{background:none;border:none;cursor:pointer}.post-detail__no-comments{text-align:center;color:var(--text-secondary, #888);padding:1rem}.comment{background:var(--bg-card, #fff);border:1px solid var(--border, #eee);border-radius:8px;padding:.75rem;margin-bottom:.5rem}.comment--reply{margin-left:2rem;background:var(--bg-hover, #f9f9f9)}.comment__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.comment__author{display:flex;align-items:center;gap:.4rem}.comment__avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.comment__avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--primary, #4caf50);color:#fff;font-size:.65rem;font-weight:600}.comment__username{font-weight:500;font-size:.8rem;cursor:pointer}.comment__username:hover{text-decoration:underline}.comment__date{font-size:.7rem;color:var(--text-secondary, #999)}.comment__actions{display:flex;gap:.5rem}.comment__actions button{background:none;border:none;cursor:pointer;font-size:.75rem}.comment__text{margin:0;font-size:.9rem;line-height:1.4}.trade-board__toggle{display:flex;gap:.5rem;margin-bottom:1rem}.trade-board__toggle-btn{flex:1;padding:.5rem;border:1px solid var(--border, #ddd);border-radius:8px;background:var(--bg-card, #fff);cursor:pointer;font-size:.85rem;transition:all .2s}.trade-board__toggle-btn:hover{background:var(--bg-hover, #f5f5f5)}.trade-board__toggle-btn--active{background:var(--primary, #4caf50);color:#fff;border-color:var(--primary, #4caf50)}.trade-board__filters{display:flex;gap:.5rem;margin-bottom:1rem}.trade-board__filters select{padding:.4rem;border:1px solid var(--border, #ddd);border-radius:6px;background:var(--bg-card, #fff);font-size:.85rem;color:var(--text-primary, #333)}.trade-board__new-btn{width:100%;padding:.7rem;border:2px dashed var(--primary, #4caf50);border-radius:8px;background:transparent;color:var(--primary, #4caf50);cursor:pointer;font-weight:600;margin-bottom:1rem}.trade-board__new-btn:hover{background:var(--primary, #4caf50);color:#fff}.trade-board__form{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:10px;padding:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.6rem}.trade-board__form input,.trade-board__form textarea,.trade-board__form select{padding:.5rem;border:1px solid var(--border, #ddd);border-radius:6px;font-size:.9rem;background:var(--bg-input, #fafafa);color:var(--text-primary, #333)}.trade-board__form input:focus,.trade-board__form textarea:focus,.trade-board__form select:focus{outline:none;border-color:var(--primary, #4caf50)}.trade-board__form-row{display:flex;gap:.5rem}.trade-board__form-row>*{flex:1}.trade-board__submit{padding:.5rem 1rem;background:var(--primary, #4caf50);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:600}.trade-board__loading,.trade-board__empty{text-align:center;color:var(--text-secondary, #888);padding:2rem}.trade-card{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:10px;padding:1rem;margin-bottom:.75rem}.trade-card--closed{opacity:.7}.trade-card__header{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem;flex-wrap:wrap}.trade-card__type{color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.trade-card__category{font-size:.8rem;color:var(--text-secondary, #666)}.trade-card__status{font-size:.75rem;margin-left:auto}.trade-card__status--reserve{color:#ff9800}.trade-card__status--cloture{color:#4caf50}.trade-card__title{font-size:1.05rem;margin:0 0 .3rem}.trade-card__desc{font-size:.85rem;color:var(--text-secondary, #555);margin:0 0 .5rem}.trade-card__info{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-secondary, #666);margin-bottom:.5rem}.trade-card__footer{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;border-top:1px solid var(--border, #eee)}.trade-card__author{display:flex;align-items:center;gap:.5rem}.trade-card__actions{display:flex;gap:.3rem}.trade-card__actions button{padding:.3rem .6rem;border:1px solid var(--border, #ddd);border-radius:6px;background:var(--bg-card, #fff);cursor:pointer;font-size:.75rem}.trade-card__actions button:hover{background:var(--bg-hover, #f5f5f5)}.trade-card__contact{background:var(--primary, #4caf50)!important;color:#fff!important;border-color:var(--primary, #4caf50)!important}.trade-card__contact:hover{opacity:.9}.conversations{display:flex;gap:1rem;min-height:500px}.conversations__locked{text-align:center;color:var(--text-secondary, #888);padding:2rem}.conversations__list{width:300px;flex-shrink:0;border:1px solid var(--border, #e0e0e0);border-radius:10px;overflow:hidden;background:var(--bg-card, #fff)}.conversations__list h3{padding:.75rem;margin:0;border-bottom:1px solid var(--border, #eee);font-size:.9rem}.conversations__empty{padding:1rem;color:var(--text-secondary, #888);font-size:.85rem;text-align:center}.conversations__item{display:flex;gap:.5rem;padding:.75rem;cursor:pointer;border-bottom:1px solid var(--border, #f0f0f0);transition:background .2s}.conversations__item:hover{background:var(--bg-hover, #f9f9f9)}.conversations__item--active{background:#4caf5014}.conversations__item--unread{font-weight:600}.conversations__item-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;flex-shrink:0}.conversations__item-avatar img{width:100%;height:100%;object-fit:cover}.conversations__item-avatar--placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--primary, #4caf50);color:#fff;font-weight:600}.conversations__item-info{flex:1;min-width:0}.conversations__item-top{display:flex;justify-content:space-between;align-items:center}.conversations__item-name{font-size:.85rem}.conversations__item-badge{background:#e53935;color:#fff;font-size:.7rem;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-weight:600}.conversations__item-ann{font-size:.7rem;color:var(--primary, #4caf50);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversations__item-preview{font-size:.8rem;color:var(--text-secondary, #888);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversations__chat{flex:1;border:1px solid var(--border, #e0e0e0);border-radius:10px;display:flex;flex-direction:column;background:var(--bg-card, #fff);overflow:hidden}.conversations__chat--empty{align-items:center;justify-content:center}.conversations__chat-placeholder{color:var(--text-secondary, #888)}.conversations__chat-header{display:flex;align-items:center;gap:.5rem;padding:.75rem;border-bottom:1px solid var(--border, #eee)}.conversations__chat-name{font-weight:600;font-size:.9rem}.conversations__chat-ann{font-size:.75rem;color:var(--text-secondary, #888)}.conversations__back{background:none;border:none;cursor:pointer;font-size:1.2rem;display:none}.conversations__messages{flex:1;overflow-y:auto;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.conversations__message{max-width:75%;padding:.6rem .8rem;border-radius:12px;font-size:.9rem}.conversations__message p{margin:0;line-height:1.4}.conversations__message-time{font-size:.65rem;color:var(--text-secondary, #999);margin-top:.2rem;display:block}.conversations__message--mine{align-self:flex-end;background:var(--primary, #4caf50);color:#fff;border-bottom-right-radius:4px}.conversations__message--mine .conversations__message-time{color:#ffffffb3}.conversations__message--theirs{align-self:flex-start;background:var(--bg-hover, #f0f0f0);border-bottom-left-radius:4px}.conversations__input{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--border, #eee)}.conversations__input input{flex:1;padding:.5rem .75rem;border:1px solid var(--border, #ddd);border-radius:20px;background:var(--bg-input, #fafafa);color:var(--text-primary, #333);font-size:.9rem}.conversations__input input:focus{outline:none;border-color:var(--primary, #4caf50)}.conversations__input button{padding:.5rem 1rem;background:var(--primary, #4caf50);color:#fff;border:none;border-radius:20px;cursor:pointer;font-weight:600}.conversations__input button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.conversations{flex-direction:column;min-height:auto}.conversations__list{width:100%}.conversations__list--hidden-mobile{display:none}.conversations__back{display:block}.conversations__chat{min-height:400px}.post-feed__form-row,.trade-board__form-row,.trade-board__filters{flex-direction:column}}.community-rules-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.community-rules-modal{background:var(--bg, #fff);border-radius:16px;max-width:640px;width:100%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.community-rules-modal__header{padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border, #e0e0e0);text-align:center}.community-rules-modal__header h2{margin:0 0 .5rem;font-size:1.3rem}.community-rules-modal__header p{margin:0;color:var(--text-secondary, #666);font-size:.9rem}.community-rules-modal__body{padding:1rem 1.5rem;overflow-y:auto;flex:1}.community-rules-modal__footer{padding:1rem 1.5rem 1.5rem;border-top:1px solid var(--border, #e0e0e0)}.community-rules-modal__disclaimer{font-size:.8rem;color:var(--text-secondary, #666);margin:0 0 1rem;text-align:center;font-style:italic}.community-rules-modal__actions{display:flex;gap:.75rem;justify-content:center}.community-rules-modal__actions .btn-primary,.community-rules-modal__actions .btn-secondary{padding:.7rem 1.5rem;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;border:none}.community-rules-modal__actions .btn-primary{background:var(--primary, #22c55e);color:#fff}.community-rules-modal__actions .btn-primary:hover{filter:brightness(1.1)}.community-rules-modal__actions .btn-secondary{background:var(--bg-secondary, #f1f5f9);color:var(--text-secondary, #666)}.community-rules-modal__actions .btn-secondary:hover{background:var(--border, #e0e0e0)}.community-rule{display:flex;gap:.75rem;padding:.75rem 0;border-bottom:1px solid var(--border-light, #f0f0f0)}.community-rule:last-child{border-bottom:none}.community-rule__icon{font-size:1.3rem;flex-shrink:0;margin-top:2px}.community-rule strong{display:block;font-size:.9rem;margin-bottom:.2rem}.community-rule p{margin:0;font-size:.82rem;color:var(--text-secondary, #666);line-height:1.4}.settings{padding:2rem;max-width:1000px;margin:0 auto;box-sizing:border-box;overflow-x:hidden}.settings .settings-header{margin-bottom:2rem}.settings .settings-header h1{font-size:2.5rem;margin:0 0 .5rem;color:var(--primary-color, #2d6a4f)}.settings .settings-header .subtitle{color:#666;font-size:1.1rem;margin:0}.settings .settings-tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.settings .settings-tabs::-webkit-scrollbar{display:none}.settings .settings-tabs .tab{padding:1rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;color:#666;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s;white-space:nowrap}.settings .settings-tabs .tab:hover{color:var(--primary-color, #2d6a4f);background:#f5f5f5}.settings .settings-tabs .tab.active{color:var(--primary-color, #2d6a4f);border-bottom-color:var(--primary-color, #2d6a4f);font-weight:600}.settings .settings-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:2rem;margin-bottom:2rem}.settings .tab-content .section{margin-bottom:2.5rem}.settings .tab-content .section:last-child{margin-bottom:0}.settings .tab-content .section h2{font-size:1.5rem;margin:0 0 .75rem;color:#333}.settings .tab-content .section .section-description{color:#666;margin:0 0 1.5rem}.settings .tab-content .form-group{margin-bottom:1.5rem}.settings .tab-content .form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.settings .tab-content .form-group input,.settings .tab-content .form-group select,.settings .tab-content .form-group textarea{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s;box-sizing:border-box}.settings .tab-content .form-group input:focus,.settings .tab-content .form-group select:focus,.settings .tab-content .form-group textarea:focus{outline:none;border-color:var(--primary-color, #2d6a4f)}.settings .tab-content .form-group textarea{resize:vertical;font-family:inherit}.settings .tab-content .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.settings .tab-content .form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem;border-top:2px solid #f0f0f0}.settings .tab-content .btn-primary,.settings .tab-content .btn-secondary{padding:.75rem 2rem;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s}.settings .tab-content .btn-primary{background:var(--primary-color, #2d6a4f);color:#fff}.settings .tab-content .btn-primary:hover{background:#1b5e3f}.settings .tab-content .btn-secondary{background:#f5f5f5;color:#666}.settings .tab-content .btn-secondary:hover{background:#e0e0e0}.settings .tab-content .settings-list{display:flex;flex-direction:column;gap:1rem}.settings .tab-content .setting-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#f8f9fa;border-radius:8px;transition:background .3s}.settings .tab-content .setting-item:hover{background:#f0f1f2}.settings .tab-content .setting-item .setting-info{flex:1}.settings .tab-content .setting-item .setting-info h3{margin:0 0 .25rem;font-size:1rem;color:#333}.settings .tab-content .setting-item .setting-info p{margin:0;font-size:.9rem;color:#666}.settings .tab-content .toggle{position:relative;display:inline-block;width:52px;height:28px;cursor:pointer}.settings .tab-content .toggle input{opacity:0;width:0;height:0}.settings .tab-content .toggle input:checked+.toggle-slider{background-color:var(--primary-color, #2d6a4f)}.settings .tab-content .toggle input:checked+.toggle-slider:before{transform:translate(24px)}.settings .tab-content .toggle .toggle-slider{position:absolute;inset:0;background-color:#ccc;transition:.4s;border-radius:28px}.settings .tab-content .toggle .toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}.settings .tab-content .data-actions{display:flex;gap:1rem;margin-top:1rem}.settings .settings-admin-zone{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #42a5f5;border-radius:12px;padding:2rem;margin-bottom:1.5rem}.settings .settings-admin-zone h2{margin:0 0 .5rem;color:#1565c0;font-size:1.5rem}.settings .settings-admin-zone p{margin:0 0 1rem;color:#1e88e5;font-size:.95rem}.settings .settings-admin-zone .btn-admin{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;background:#1565c0;color:#fff;border:none;transition:all .3s}.settings .settings-admin-zone .btn-admin:hover{background:#0d47a1;transform:translateY(-1px)}.settings .settings-danger-zone{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:2px solid #ef5350;border-radius:12px;padding:2rem}.settings .settings-danger-zone h2{margin:0 0 1rem;color:#c62828;font-size:1.5rem}.settings .settings-danger-zone .danger-actions{display:flex;gap:1rem;flex-wrap:wrap}.settings .settings-danger-zone .btn-danger,.settings .settings-danger-zone .btn-danger-outline{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s}.settings .settings-danger-zone .btn-danger{background:#c62828;color:#fff;border:none}.settings .settings-danger-zone .btn-danger:hover{background:#b71c1c}.settings .settings-danger-zone .btn-danger-outline{background:transparent;color:#c62828;border:2px solid #c62828}.settings .settings-danger-zone .btn-danger-outline:hover{background:#c62828;color:#fff}@media(max-width:768px){.settings{padding:.75rem}.settings .settings-header h1{font-size:1.75rem}.settings .settings-tabs .tab{padding:.75rem 1rem;font-size:.9rem}.settings .settings-content{padding:1rem}.settings .tab-content .form-row{grid-template-columns:1fr}.settings .tab-content .form-actions{flex-direction:column}.settings .tab-content .form-actions button{width:100%}.settings .tab-content .setting-item{flex-direction:column;align-items:flex-start;gap:1rem}.settings .tab-content .data-actions{flex-direction:column}.settings .tab-content .data-actions button{width:100%}.settings .settings-danger-zone .danger-actions{flex-direction:column}.settings .settings-danger-zone .danger-actions button{width:100%}}.subscription-status{margin-bottom:1.5rem}.subscription-status .status-badge{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:12px;margin-bottom:1rem}.subscription-status .status-badge .badge-icon{font-size:2rem;line-height:1}.subscription-status .status-badge strong{display:block;font-size:1.1rem;margin-bottom:.25rem}.subscription-status .status-badge p{margin:0;color:#ffffffe6;font-size:.9rem}.subscription-status .status-badge.vip{background:linear-gradient(135deg,gold,#ffed4e);color:#333}.subscription-status .status-badge.vip p{color:#000000b3}.subscription-status .status-badge.premium{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.subscription-status .status-badge.free{background:linear-gradient(135deg,#52c234,#40916c);color:#fff}.fourthwall-check{background:#f8f9fa;padding:1.5rem;border-radius:12px;border:2px dashed #dee2e6}.fourthwall-check .info-text{margin:0 0 1rem;color:#666;font-size:.95rem;line-height:1.5}.fourthwall-check .message{margin-top:1rem;padding:.75rem 1rem;border-radius:8px;font-weight:500}.fourthwall-check .message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.fourthwall-check .message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.profile-message{padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-weight:500;animation:slideIn .3s ease}.profile-message--success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.profile-message--error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.profile-loading .spinner{width:40px;height:40px;border:3px solid #ddd;border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite}.profile-avatar-section{display:flex;align-items:center;gap:1.5rem}.profile-avatar-section .avatar-wrapper{position:relative;width:80px;height:80px;border-radius:50%;cursor:pointer;flex-shrink:0;overflow:hidden}.profile-avatar-section .avatar-wrapper:hover .avatar-overlay{opacity:1}.profile-avatar-section .avatar-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.profile-avatar-section .avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4caf50,#2d6a4f);color:#fff;font-size:2rem;font-weight:700;border-radius:50%}.profile-avatar-section .avatar-overlay{position:absolute;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;font-size:1.5rem;opacity:0;transition:opacity .2s;border-radius:50%}.profile-avatar-section .avatar-info h3{margin:0 0 .25rem;font-size:1.25rem;color:var(--text-primary, #333)}.profile-avatar-section .avatar-info p{margin:0;color:var(--text-secondary, #666);font-size:.9rem}.chips-group{display:flex;flex-wrap:wrap;gap:.5rem}.chip{display:inline-flex;align-items:center;gap:.3rem;padding:.5rem 1rem;border-radius:20px;border:2px solid #ddd;background:var(--card-bg, white);color:var(--text-primary, #555);font-size:.85rem;cursor:pointer;transition:all .2s}.chip:hover{border-color:#4caf50;background:#f1f8e9}.chip--active{border-color:#4caf50;background:#e8f5e9;color:#2e7d32;font-weight:600}.home-page{min-height:100vh;height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b);color:#fff;overflow:hidden}.home-page .home-hero{position:relative;min-height:100vh;height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:2rem}.home-page .home-hero .hero-background{position:absolute;inset:0;overflow:hidden;opacity:.1}.home-page .home-hero .hero-background .floating-element{position:absolute;font-size:3rem;animation:float 20s infinite ease-in-out;filter:blur(1px)}.home-page .home-hero .hero-background .floating-element.plant-1{top:10%;left:10%;animation-delay:0s}.home-page .home-hero .hero-background .floating-element.plant-2{top:20%;right:15%;animation-delay:2s}.home-page .home-hero .hero-background .floating-element.plant-3{bottom:30%;left:20%;animation-delay:4s}.home-page .home-hero .hero-background .floating-element.plant-4{bottom:20%;right:10%;animation-delay:6s}.home-page .home-hero .hero-background .floating-element.plant-5{top:50%;left:50%;animation-delay:8s}.home-page .home-hero .hero-content{position:relative;text-align:center;max-width:900px;z-index:1}.home-page .home-hero .hero-content .logo-container{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:2rem}.home-page .home-hero .hero-content .logo-container .logo{font-size:4rem;animation:pulse 2s infinite}.home-page .home-hero .hero-content .logo-container .brand-name{font-size:3rem;font-weight:800;margin:0;background:linear-gradient(135deg,#22c55e,#4ade80);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-page .home-hero .hero-content .hero-title{font-size:3.5rem;font-weight:800;margin:0 0 1.5rem;line-height:1.2;color:#fff}.home-page .home-hero .hero-content .hero-description{font-size:1.25rem;color:#94a3b8;margin:0 0 3rem;line-height:1.6}.home-page .home-hero .hero-content .hero-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:3rem}.home-page .home-hero .hero-content .hero-actions .btn-primary,.home-page .home-hero .hero-content .hero-actions .btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:1rem 2rem;border-radius:12px;text-decoration:none;font-weight:600;font-size:1.125rem;transition:all .3s ease;border:2px solid transparent}.home-page .home-hero .hero-content .hero-actions .btn-primary .btn-icon,.home-page .home-hero .hero-content .hero-actions .btn-secondary .btn-icon{font-size:1.5rem}.home-page .home-hero .hero-content .hero-actions .btn-primary{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 4px 20px #22c55e66}.home-page .home-hero .hero-content .hero-actions .btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px #22c55e80}.home-page .home-hero .hero-content .hero-actions .btn-secondary{background:transparent;color:#fff;border-color:#fff3}.home-page .home-hero .hero-content .hero-actions .btn-secondary:hover{background:#ffffff1a;border-color:#fff6;transform:translateY(-2px)}.home-page .home-hero .hero-content .hero-features{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.home-page .home-hero .hero-content .hero-features .feature-badge{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:999px;font-size:.875rem;color:#cbd5e1;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home-page .home-hero .hero-content .hero-features .feature-badge .icon{font-size:1.25rem}@keyframes float{0%,to{transform:translateY(0) translate(0) rotate(0)}25%{transform:translateY(-30px) translate(20px) rotate(5deg)}50%{transform:translateY(-60px) translate(-20px) rotate(-5deg)}75%{transform:translateY(-30px) translate(20px) rotate(5deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media(max-width:768px){.home-page .home-hero .hero-content .logo-container .logo{font-size:3rem}.home-page .home-hero .hero-content .logo-container .brand-name,.home-page .home-hero .hero-content .hero-title{font-size:2rem}.home-page .home-hero .hero-content .hero-description{font-size:1rem}.home-page .home-hero .hero-content .hero-actions{flex-direction:column}.home-page .home-hero .hero-content .hero-actions .btn-primary,.home-page .home-hero .hero-content .hero-actions .btn-secondary{width:100%;justify-content:center}.home-page .home-hero .hero-content .hero-features .feature-badge{font-size:.75rem;padding:.5rem 1rem}.home-page .home-stats{grid-template-columns:1fr;gap:2rem}.home-page .home-stats .stat-item .stat-number{font-size:2rem}.home-page .home-cta h3{font-size:1.75rem}.home-page .home-cta p{font-size:1rem}}.discover-page .hero-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4rem 2rem;text-align:center}.discover-page .hero-section .hero-content{max-width:800px;margin:0 auto}.discover-page .hero-section .hero-content h1{font-size:3rem;margin:0 0 1rem;font-weight:700}.discover-page .hero-section .hero-content .hero-subtitle{font-size:1.25rem;margin:0 0 2rem;opacity:.95}.discover-page .hero-section .hero-content .hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.discover-page .hero-section .hero-content .hero-cta .btn-primary,.discover-page .hero-section .hero-content .hero-cta .btn-secondary{padding:.75rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;text-decoration:none;transition:all .3s;display:inline-block}.discover-page .hero-section .hero-content .hero-cta .btn-primary{background:#fff;color:#667eea}.discover-page .hero-section .hero-content .hero-cta .btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.discover-page .hero-section .hero-content .hero-cta .btn-secondary{background:transparent;color:#fff;border:2px solid white}.discover-page .hero-section .hero-content .hero-cta .btn-secondary:hover{background:#fff;color:#667eea}.discover-page .features-section{padding:4rem 2rem;background:#f9f9f9}.discover-page .features-section .container{max-width:1200px;margin:0 auto}.discover-page .features-section .container h2{text-align:center;font-size:2.5rem;margin:0 0 1rem;color:#333}.discover-page .features-section .container .section-intro{text-align:center;max-width:700px;margin:0 auto 3rem;color:#666;font-size:1.1rem;line-height:1.6}.discover-page .features-section .container .features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.discover-page .features-section .container .features-grid .feature-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .3s}.discover-page .features-section .container .features-grid .feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.discover-page .features-section .container .features-grid .feature-card .feature-icon{font-size:3rem;margin-bottom:1rem}.discover-page .features-section .container .features-grid .feature-card h3{font-size:1.5rem;margin:0 0 .75rem;color:#333}.discover-page .features-section .container .features-grid .feature-card h3 .feature-tag{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;font-size:.7rem;font-weight:600;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;border-radius:4px;vertical-align:middle;text-transform:uppercase;letter-spacing:.5px}.discover-page .features-section .container .features-grid .feature-card p{color:#666;margin:0 0 1rem;line-height:1.5}.discover-page .features-section .container .features-grid .feature-card .benefits-list{list-style:none;padding:0;margin:0}.discover-page .features-section .container .features-grid .feature-card .benefits-list li{padding:.25rem 0;color:#555;font-size:.95rem}.discover-page .how-it-works{padding:4rem 2rem;background:#fff}.discover-page .how-it-works .container{max-width:1200px;margin:0 auto}.discover-page .how-it-works .container h2{text-align:center;font-size:2.5rem;margin:0 0 3rem;color:#333}.discover-page .how-it-works .container .steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.discover-page .how-it-works .container .steps .step{text-align:center}.discover-page .how-it-works .container .steps .step .step-number{width:60px;height:60px;background:#4caf50;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin:0 auto 1rem}.discover-page .how-it-works .container .steps .step h3{font-size:1.25rem;margin:0 0 .5rem;color:#333}.discover-page .how-it-works .container .steps .step p{color:#666;line-height:1.5}.discover-page .why-section{padding:4rem 2rem;background:#f9f9f9}.discover-page .why-section .container{max-width:1200px;margin:0 auto}.discover-page .why-section .container h2{text-align:center;font-size:2.5rem;margin:0 0 3rem;color:#333}.discover-page .why-section .container .why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.discover-page .why-section .container .why-grid .why-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center}.discover-page .why-section .container .why-grid .why-card .why-icon{font-size:3rem;display:block;margin-bottom:1rem}.discover-page .why-section .container .why-grid .why-card h3{font-size:1.25rem;margin:0 0 .75rem;color:#333}.discover-page .why-section .container .why-grid .why-card p{color:#666;line-height:1.6;margin:0}.discover-page .cta-section{padding:4rem 2rem;background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff;text-align:center}.discover-page .cta-section .container{max-width:800px;margin:0 auto}.discover-page .cta-section .container h2{font-size:2.5rem;margin:0 0 1rem}.discover-page .cta-section .container p{font-size:1.2rem;margin:0 0 2rem;opacity:.95}.discover-page .cta-section .container .btn-primary-large{display:inline-block;padding:1rem 3rem;background:#fff;color:#4caf50;font-size:1.2rem;font-weight:600;border-radius:8px;text-decoration:none;transition:all .3s}.discover-page .cta-section .container .btn-primary-large:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.discover-page .cta-section .container .cta-note{margin-top:1rem;font-size:.9rem;opacity:.9}@media(max-width:768px){.discover-page .hero-section{padding:2rem 1rem}.discover-page .hero-section .hero-content h1{font-size:2rem}.discover-page .features-section,.discover-page .how-it-works,.discover-page .why-section,.discover-page .cta-section{padding:2rem 1rem}.discover-page .features-section h2,.discover-page .how-it-works h2,.discover-page .why-section h2,.discover-page .cta-section h2{font-size:2rem!important}}.pricing-page .pricing-header{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#f5f5f5,#e0e0e0)}.pricing-page .pricing-header h1{font-size:2.5rem;margin:0 0 1rem;color:#333}.pricing-page .pricing-header .subtitle{font-size:1.2rem;color:#666;margin:0 0 2rem}.pricing-page .pricing-header .billing-toggle{display:inline-flex;background:#fff;border-radius:8px;padding:4px;box-shadow:0 2px 8px #0000001a}.pricing-page .pricing-header .billing-toggle button{padding:.5rem 1.5rem;border:none;background:transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#666;border-radius:6px;transition:all .3s;position:relative}.pricing-page .pricing-header .billing-toggle button.active{background:#4caf50;color:#fff}.pricing-page .pricing-header .billing-toggle button .badge{position:absolute;top:-8px;right:-8px;background:#ff9800;color:#fff;font-size:.7rem;padding:2px 6px;border-radius:12px;font-weight:600}.pricing-page .plans-section{padding:3rem 2rem;max-width:1200px;margin:0 auto}.pricing-page .plans-section .plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:2rem;align-items:start}.pricing-page .plans-section .plans-grid .plan-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:2rem;position:relative;transition:all .3s}.pricing-page .plans-section .plans-grid .plan-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.pricing-page .plans-section .plans-grid .plan-card.highlighted{border-color:#4caf50;box-shadow:0 4px 16px #4caf5033}.pricing-page .plans-section .plans-grid .plan-card .popular-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:#4caf50;color:#fff;padding:.25rem 1rem;border-radius:12px;font-size:.85rem;font-weight:600}.pricing-page .plans-section .plans-grid .plan-card .plan-header{text-align:center;padding-bottom:2rem;border-bottom:1px solid #e0e0e0;margin-bottom:2rem}.pricing-page .plans-section .plans-grid .plan-card .plan-header h2{font-size:1.75rem;margin:0 0 .5rem;color:#333}.pricing-page .plans-section .plans-grid .plan-card .plan-header .plan-description{color:#666;margin:0 0 1.5rem;font-size:.95rem}.pricing-page .plans-section .plans-grid .plan-card .plan-header .plan-price{display:flex;align-items:baseline;justify-content:center;gap:.25rem}.pricing-page .plans-section .plans-grid .plan-card .plan-header .plan-price .currency{font-size:1.5rem;font-weight:600;color:#333}.pricing-page .plans-section .plans-grid .plan-card .plan-header .plan-price .price-amount{font-size:3rem;font-weight:700;color:#333}.pricing-page .plans-section .plans-grid .plan-card .plan-header .plan-price .price-period{font-size:1.2rem;color:#666}.pricing-page .plans-section .plans-grid .plan-card .plan-header .savings{color:#4caf50;font-weight:600;margin:.5rem 0 0}.pricing-page .plans-section .plans-grid .plan-card .features-list{list-style:none;padding:0;margin:0 0 2rem}.pricing-page .plans-section .plans-grid .plan-card .features-list li{padding:.5rem 0;display:flex;align-items:center;gap:.75rem;font-size:.95rem}.pricing-page .plans-section .plans-grid .plan-card .features-list li .icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.pricing-page .plans-section .plans-grid .plan-card .features-list li.included{color:#333}.pricing-page .plans-section .plans-grid .plan-card .features-list li.included .icon{background:#4caf50;color:#fff}.pricing-page .plans-section .plans-grid .plan-card .features-list li.not-included{color:#999}.pricing-page .plans-section .plans-grid .plan-card .features-list li.not-included .icon{background:#e0e0e0;color:#999}.pricing-page .plans-section .plans-grid .plan-card .cta-button{display:block;width:100%;padding:.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;text-align:center;text-decoration:none;transition:all .3s}.pricing-page .plans-section .plans-grid .plan-card .cta-button.primary{background:#4caf50;color:#fff}.pricing-page .plans-section .plans-grid .plan-card .cta-button.primary:hover{background:#45a049;transform:translateY(-2px)}.pricing-page .plans-section .plans-grid .plan-card .cta-button.secondary{background:#fff;color:#4caf50;border:2px solid #4caf50}.pricing-page .plans-section .plans-grid .plan-card .cta-button.secondary:hover{background:#f1f8f4}.pricing-page .comparison-section{padding:3rem 2rem;background:#f9f9f9}.pricing-page .comparison-section .container{max-width:900px;margin:0 auto}.pricing-page .comparison-section .container h2{text-align:center;font-size:2rem;margin:0 0 2rem;color:#333}.pricing-page .comparison-section .container .comparison-table{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.pricing-page .comparison-section .container .comparison-table table{width:100%;border-collapse:collapse}.pricing-page .comparison-section .container .comparison-table table thead{background:#4caf50;color:#fff}.pricing-page .comparison-section .container .comparison-table table thead th{padding:1rem;text-align:left;font-weight:600}.pricing-page .comparison-section .container .comparison-table table thead th:first-child{width:50%}.pricing-page .comparison-section .container .comparison-table table tbody tr{border-bottom:1px solid #f0f0f0}.pricing-page .comparison-section .container .comparison-table table tbody tr:hover{background:#f9f9f9}.pricing-page .comparison-section .container .comparison-table table tbody tr td{padding:.75rem 1rem}.pricing-page .comparison-section .container .comparison-table table tbody tr td:first-child{font-weight:500;color:#333}.pricing-page .comparison-section .container .comparison-table table tbody tr td:not(:first-child){text-align:left;color:#666}.pricing-page .comparison-section .container .comparison-table table tbody tr td:not(:first-child) .check{color:#4caf50;font-weight:700;font-size:1.1rem}.pricing-page .comparison-section .container .comparison-table table tbody tr td:not(:first-child) .cross{color:#e53935;font-weight:700;font-size:1.1rem}.pricing-page .faq-section{padding:3rem 2rem}.pricing-page .faq-section .container{max-width:900px;margin:0 auto}.pricing-page .faq-section .container h2{text-align:center;font-size:2rem;margin:0 0 2rem;color:#333}.pricing-page .faq-section .container .faq-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.pricing-page .faq-section .container .faq-grid .faq-item h3{font-size:1.1rem;margin:0 0 .5rem;color:#333}.pricing-page .faq-section .container .faq-grid .faq-item p{margin:0;color:#666;line-height:1.6}.pricing-page .cta-final{padding:3rem 2rem;background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff;text-align:center}.pricing-page .cta-final .container{max-width:700px;margin:0 auto}.pricing-page .cta-final .container h2{font-size:2rem;margin:0 0 .75rem}.pricing-page .cta-final .container p{font-size:1.1rem;margin:0 0 1.5rem;opacity:.95}.pricing-page .cta-final .container .btn-primary-large{display:inline-block;padding:1rem 3rem;background:#fff;color:#4caf50;border:none;border-radius:8px;font-size:1.2rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .3s}.pricing-page .cta-final .container .btn-primary-large:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003}.pricing-page .cta-final .container .note{margin-top:1rem;font-size:.9rem;opacity:.9}@media(max-width:768px){.pricing-page .pricing-header h1{font-size:2rem}.pricing-page .plans-section .plans-grid{grid-template-columns:1fr}.pricing-page .comparison-section .comparison-table{overflow-x:auto}.pricing-page .faq-section .faq-grid{grid-template-columns:1fr}}.about-page{min-height:calc(100vh - 64px);background:#f9f9f9}.about-page .about-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:3rem 2rem;text-align:center}.about-page .about-header .about-back-btn{display:inline-flex;align-items:center;gap:.3rem;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:.4rem 1rem;border-radius:8px;cursor:pointer;font-size:.85rem;margin-bottom:1rem;transition:background .2s}.about-page .about-header .about-back-btn:hover{background:#ffffff59}.about-page .about-header h1{font-size:2.5rem;margin:0 0 .5rem}.about-page .about-header p{margin:0;font-size:1.2rem;opacity:.95}.about-page .about-content{max-width:1200px;margin:0 auto;padding:2rem}.about-page .about-content .tabs-nav{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem;background:#fff;padding:.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.about-page .about-content .tabs-nav .tab-button{flex:1;min-width:150px;padding:.75rem 1rem;background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;color:#666;transition:all .3s}.about-page .about-content .tabs-nav .tab-button:hover{background:#f5f5f5;color:#333}.about-page .about-content .tabs-nav .tab-button.active{background:#4caf50;color:#fff}.about-page .about-content .tab-content{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;min-height:600px}.about-page .about-content .tab-content .content-section h2{font-size:2rem;margin:0 0 2rem;color:#333;padding-bottom:1rem;border-bottom:3px solid #4caf50}.about-page .about-content .tab-content .content-section h3{font-size:1.5rem;margin:2rem 0 1rem;color:#444}.about-page .about-content .tab-content .content-section h4{font-size:1.2rem;margin:1.5rem 0 .75rem;color:#555}.about-page .about-content .tab-content .content-section p{line-height:1.8;color:#666;margin:0 0 1rem}.about-page .about-content .tab-content .content-section ul,.about-page .about-content .tab-content .content-section ol{line-height:1.8;color:#666;margin:0 0 1rem;padding-left:2rem}.about-page .about-content .tab-content .content-section ul li,.about-page .about-content .tab-content .content-section ol li{margin:.5rem 0}.about-page .about-content .tab-content .content-section a{color:#4caf50;text-decoration:none;font-weight:500}.about-page .about-content .tab-content .content-section a:hover{text-decoration:underline}.about-page .about-content .tab-content .content-section strong{color:#333;font-weight:600}@media(max-width:768px){.about-page .about-header{padding:2rem 1rem}.about-page .about-header h1{font-size:2rem}.about-page .about-content{padding:1rem}.about-page .about-content .tabs-nav .tab-button{flex:1 1 45%;min-width:0}.about-page .about-content .tab-content{padding:1.5rem}.about-page .about-content .tab-content .content-section h2{font-size:1.5rem}.about-page .about-content .tab-content .content-section h3{font-size:1.25rem}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-light) 0%,var(--secondary-light) 100%);padding:2rem}.auth-card{width:100%;max-width:440px;background:var(--card-bg);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-xl)}.auth-card__header{text-align:center;margin-bottom:2rem}.auth-card__logo{color:var(--primary);margin-bottom:1rem;font-size:3rem}.auth-card__title{font-size:2rem;color:var(--text-primary);margin-bottom:.5rem}.auth-card__subtitle{color:var(--text-secondary);font-size:.875rem}.auth-form__error{padding:.875rem;background:#fee2e2;border:1px solid var(--danger);border-radius:var(--radius-md);color:#991b1b;font-size:.875rem;margin-bottom:1.5rem}.auth-form__footer{margin-top:1.5rem;text-align:center;color:var(--text-secondary);font-size:.875rem}.auth-form__footer p{margin-bottom:.5rem}.auth-form__link{color:var(--primary);font-weight:600;text-decoration:none;transition:color var(--transition-base) ease}.auth-form__link:hover{color:var(--primary-dark);text-decoration:underline}.auth-form .form-label{display:flex;align-items:center;gap:.5rem}.guide{padding:1.5rem;max-width:1200px;margin:0 auto}.guide__header{margin-bottom:1.5rem}.guide__header h1{font-size:1.75rem;color:var(--text-primary);margin-bottom:.25rem}.guide__subtitle{color:var(--text-secondary);font-size:.95rem}.guide__back{background:none;border:none;color:var(--primary);font-size:.9rem;font-weight:600;cursor:pointer;padding:0;margin-bottom:.5rem;display:inline-block}.guide__back:hover{color:var(--primary-dark)}.guide__search{position:relative;margin-bottom:1.5rem}.guide__search input{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--card-bg);color:var(--text-primary);font-size:.95rem;transition:border-color var(--transition-fast)}.guide__search input::placeholder{color:var(--text-tertiary)}.guide__search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.guide__search-clear{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-tertiary);font-size:1.1rem;cursor:pointer;padding:.25rem;line-height:1}.guide__search-clear:hover{color:var(--text-primary)}.guide__search-count{color:var(--text-secondary);font-size:.875rem;margin-bottom:1rem}.guide__search-item{display:flex;align-items:flex-start;gap:.75rem;width:100%;text-align:left;padding:1rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-bottom:.5rem}.guide__search-item:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.guide__search-item-icon{font-size:1.5rem;flex-shrink:0;margin-top:.1rem}.guide__search-item-info{flex:1;min-width:0}.guide__search-item-info strong{display:block;color:var(--text-primary);font-size:.95rem;margin-bottom:.15rem}.guide__search-item-info span{display:block;color:var(--text-tertiary);font-size:.8rem;margin-bottom:.25rem}.guide__search-item-info p{color:var(--text-secondary);font-size:.85rem;line-height:1.4;margin:0}.guide__categories{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.guide__category-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;text-align:left;cursor:pointer;transition:all var(--transition-base);display:flex;flex-direction:column;gap:.35rem}.guide__category-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.guide__category-icon{font-size:2rem;margin-bottom:.25rem}.guide__category-title{font-size:1.05rem;color:var(--text-primary);font-weight:700}.guide__category-desc{font-size:.85rem;color:var(--text-secondary);line-height:1.4;margin:0}.guide__category-count{font-size:.8rem;color:var(--primary);font-weight:600;margin-top:auto;padding-top:.5rem}.guide__subcategory{margin-bottom:2rem}.guide__subcategory-title{font-size:1.15rem;color:var(--text-primary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid var(--primary-light)}.guide__articles{display:flex;flex-direction:column;gap:.5rem}.guide__empty{text-align:center;padding:3rem 1rem;color:var(--text-tertiary)}.guide__empty span{font-size:2.5rem;display:block;margin-bottom:.5rem}.guide-article{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;transition:border-color var(--transition-fast)}.guide-article--open{border-color:var(--primary)}.guide-article__header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.875rem 1rem;background:none;border:none;cursor:pointer;text-align:left;gap:.75rem;transition:background var(--transition-fast)}.guide-article__header:hover{background:var(--bg-secondary)}.guide-article__info{flex:1;min-width:0}.guide-article__title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0}.guide-article__summary{font-size:.825rem;color:var(--text-secondary);margin:.15rem 0 0;line-height:1.3}.guide-article__chevron{flex-shrink:0;color:var(--text-tertiary);font-size:.7rem;transition:transform var(--transition-base)}.guide-article__body{max-height:0;overflow:hidden;transition:max-height .35s ease}.guide-article__content{padding:1rem;border-top:1px solid var(--border-color);color:var(--text-primary);font-size:.9rem;line-height:1.65}.guide-article__content h3{font-size:1.05rem;margin:1.25rem 0 .5rem;color:var(--primary-dark)}.guide-article__content h4{font-size:.95rem;margin:1rem 0 .4rem;color:var(--text-primary)}.guide-article__content p{margin:.4rem 0}.guide-article__content strong{color:var(--text-primary)}.guide-article__content code{background:var(--bg-secondary);padding:.15em .4em;border-radius:3px;font-size:.85em}.guide-article__content ul,.guide-article__content ol{padding-left:1.25rem;margin:.5rem 0}.guide-article__content li{margin:.2rem 0}.guide-table-wrapper{overflow-x:auto;margin:.75rem 0}.guide-table{width:100%;border-collapse:collapse;font-size:.85rem}.guide-table th,.guide-table td{padding:.5rem .75rem;text-align:left;border:1px solid var(--border-color)}.guide-table th{background:var(--bg-secondary);font-weight:600;white-space:nowrap}.guide-table td{background:var(--card-bg)}.guide-table tr:hover td{background:var(--bg-secondary)}@media(max-width:768px){.guide{padding:1rem}.guide__header h1{font-size:1.35rem}.guide__categories{grid-template-columns:1fr}}.badges-page{padding:1.5rem;max-width:1100px;margin:0 auto}.badges-header{margin-bottom:2rem}.badges-title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.badges-title-row h1{font-size:1.6rem;font-weight:700;color:var(--text-primary, #1a1a2e);margin:0}.btn-check-badges{padding:.5rem 1.2rem;border-radius:10px;border:none;background:var(--primary, #22c55e);color:#fff;font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .15s,box-shadow .15s}.btn-check-badges:hover{transform:translateY(-1px);box-shadow:0 4px 12px #22c55e4d}.badges-stats{display:flex;gap:1rem;margin-bottom:1rem}.stat-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:1rem 1.5rem;display:flex;flex-direction:column;align-items:center;min-width:100px}.stat-card .stat-value{font-size:1.5rem;font-weight:700;color:var(--primary, #22c55e)}.stat-card .stat-label{font-size:.8rem;color:var(--text-secondary, #6b7280);margin-top:.2rem}.progress-bar-wrapper{height:8px;background:var(--bg-secondary, #f1f5f9);border-radius:4px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#22c55e,#3b82f6);border-radius:4px;transition:width .5s ease}.badges-categories{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.cat-btn{padding:.4rem .9rem;border-radius:20px;border:1px solid var(--border-color, #e2e8f0);background:var(--card-bg, #fff);color:var(--text-secondary, #6b7280);font-size:.85rem;cursor:pointer;transition:all .2s}.cat-btn:hover{border-color:var(--primary, #22c55e);color:var(--primary, #22c55e)}.cat-btn.active{background:var(--primary, #22c55e);color:#fff;border-color:var(--primary, #22c55e)}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.badge-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:14px;padding:1.2rem;text-align:center;transition:transform .2s,box-shadow .2s}.badge-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014}.badge-card.unlocked{border-color:var(--rarity-color, #94a3b8);background:var(--rarity-bg, #f8f9fa)}.badge-card.locked{opacity:.65}.badge-card-icon{font-size:2.5rem;margin-bottom:.5rem}.badge-card-name{font-size:1rem;font-weight:700;color:var(--text-primary, #1a1a2e);margin:0 0 .3rem}.badge-card-desc{font-size:.8rem;color:var(--text-secondary, #6b7280);margin-bottom:.5rem;line-height:1.3}.badge-rarity{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.badge-progress{margin-top:.6rem}.badge-progress-bar{height:6px;background:var(--bg-secondary, #e2e8f0);border-radius:3px;overflow:hidden;margin-bottom:.3rem}.badge-progress-fill{height:100%;border-radius:3px;transition:width .4s ease}.badge-progress-text{font-size:.75rem;color:var(--text-secondary, #6b7280)}.btn-share-badge{margin-top:.6rem;padding:.3rem .8rem;border-radius:8px;border:1px solid var(--border-color, #e2e8f0);background:var(--card-bg, #fff);color:var(--text-primary, #1a1a2e);font-size:.8rem;cursor:pointer;transition:all .15s}.btn-share-badge:hover{border-color:var(--primary, #22c55e);color:var(--primary, #22c55e)}@media(max-width:600px){.badges-page{padding:1rem}.badges-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem}.badges-stats{gap:.5rem}.badges-stats .stat-card{padding:.7rem 1rem;min-width:auto;flex:1}}.share-button{padding:.45rem 1rem;border-radius:10px;border:1px solid var(--border-color, #e2e8f0);background:var(--card-bg, #fff);color:var(--text-primary, #1a1a2e);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.share-button:hover{border-color:var(--primary, #22c55e);color:var(--primary, #22c55e)}.share-modal-overlay{position:fixed;inset:0;z-index:9999;background:#00000080;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.share-modal{background:var(--card-bg, #fff);border-radius:16px;padding:1.5rem;max-width:360px;width:90%;text-align:center;animation:shareSlideUp .3s ease-out}.share-modal h3{font-size:1.2rem;margin:0 0 1rem;color:var(--text-primary, #1a1a2e)}@keyframes shareSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.share-platforms{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem}.share-platform-btn{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.6rem;border-radius:10px;background:var(--bg-secondary, #f8f9fa);text-decoration:none;color:var(--text-primary, #1a1a2e);transition:background .15s}.share-platform-btn:hover{background:var(--border-color, #e2e8f0)}.share-platform-btn .platform-icon{font-size:1.5rem}.share-platform-btn .platform-label{font-size:.7rem;font-weight:500}.share-copy-btn{width:100%;padding:.6rem;border-radius:10px;border:1px solid var(--border-color, #e2e8f0);background:var(--bg-secondary, #f8f9fa);color:var(--text-primary, #1a1a2e);font-size:.85rem;font-weight:600;cursor:pointer;margin-bottom:.5rem;transition:all .15s}.share-copy-btn:hover{background:var(--primary, #22c55e);color:#fff;border-color:var(--primary, #22c55e)}.share-close-btn{padding:.4rem 1rem;border:none;background:transparent;color:var(--text-secondary, #6b7280);font-size:.85rem;cursor:pointer}.referral-page{padding:1.5rem;max-width:800px;margin:0 auto}.referral-header{margin-bottom:2rem}.referral-header h1{font-size:1.6rem;font-weight:700;color:var(--text-primary, #1a1a2e);margin:0 0 .5rem}.referral-header p{color:var(--text-secondary, #6b7280);font-size:.95rem}.referral-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem}.referral-card h2{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary, #1a1a2e)}.referral-code-box{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.referral-code{font-size:1.8rem;font-weight:800;letter-spacing:2px;color:var(--primary, #22c55e);background:var(--bg-secondary, #f0fdf4);padding:.5rem 1.2rem;border-radius:10px;border:2px dashed var(--primary, #22c55e)}.btn-copy{padding:.5rem 1rem;border-radius:10px;border:1px solid var(--border-color, #e2e8f0);background:var(--card-bg, #fff);font-weight:600;font-size:.85rem;cursor:pointer;transition:all .15s}.btn-copy:hover{border-color:var(--primary, #22c55e);color:var(--primary, #22c55e)}.referral-link{margin-bottom:1rem}.referral-link .link-text{font-size:.8rem;color:var(--text-secondary, #6b7280);word-break:break-all}.referral-share-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.share-btn{padding:.5rem 1rem;border-radius:10px;border:none;font-weight:600;font-size:.85rem;cursor:pointer;transition:transform .15s;color:#fff}.share-btn:hover{transform:translateY(-1px)}.share-btn.whatsapp{background:#25d366}.share-btn.sms{background:#3b82f6}.share-btn.email{background:#6b7280}.share-btn.more{background:var(--bg-secondary, #f1f5f9);color:var(--text-primary, #1a1a2e);border:1px solid var(--border-color, #e2e8f0)}.referral-stats{margin-bottom:1.5rem}.referral-stats h2{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary, #1a1a2e)}.stats-grid{display:flex;gap:1rem}.stat-item{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:1rem 1.5rem;text-align:center;flex:1}.stat-item .stat-number{display:block;font-size:2rem;font-weight:700;color:var(--primary, #22c55e)}.stat-item .stat-desc{font-size:.8rem;color:var(--text-secondary, #6b7280)}.referral-milestones{margin-bottom:1.5rem}.referral-milestones h2{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary, #1a1a2e)}.milestones-list{display:flex;flex-direction:column;gap:.5rem}.milestone{display:flex;align-items:center;gap:1rem;background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:.8rem 1.2rem;transition:border-color .2s}.milestone.achieved{border-color:var(--primary, #22c55e);background:var(--bg-secondary, #f0fdf4)}.milestone .milestone-icon{font-size:1.5rem}.milestone .milestone-info{flex:1;display:flex;flex-direction:column}.milestone .milestone-info .milestone-count{font-weight:600;font-size:.9rem;color:var(--text-primary, #1a1a2e)}.milestone .milestone-info .milestone-reward{font-size:.8rem;color:var(--text-secondary, #6b7280)}.milestone .milestone-check{color:var(--primary, #22c55e);font-weight:700;font-size:1.2rem}.referral-how h2{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary, #1a1a2e)}.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.how-step{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:1.2rem;text-align:center}.how-step .step-num{width:36px;height:36px;border-radius:50%;background:var(--primary, #22c55e);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:.5rem}.how-step h3{font-size:.95rem;font-weight:600;margin:0 0 .3rem;color:var(--text-primary, #1a1a2e)}.how-step p{font-size:.8rem;color:var(--text-secondary, #6b7280);margin:0}@media(max-width:600px){.referral-page{padding:1rem}.referral-code{font-size:1.3rem;padding:.4rem .8rem}.how-steps{grid-template-columns:1fr}.stats-grid{flex-direction:column}}.join-referral-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0fdf4,#ecfdf5,#f0f9ff);padding:2rem}.join-card{background:#fff;border-radius:20px;padding:2.5rem;max-width:520px;width:100%;text-align:center;box-shadow:0 8px 40px #00000014}.join-icon{font-size:3rem;margin-bottom:1rem}.join-card h1{font-size:1.5rem;font-weight:700;color:#1a1a2e;margin:0 0 .5rem}.join-subtitle{color:#6b7280;font-size:.95rem;margin-bottom:1.5rem}.join-code{background:#f0fdf4;border:2px dashed #22c55e;border-radius:10px;padding:.6rem 1rem;font-size:.95rem;color:#1a1a2e;margin-bottom:1.5rem;display:inline-block}.join-code strong{color:#22c55e;letter-spacing:1px}.join-benefits{text-align:left;margin-bottom:1.5rem}.join-benefits h3{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0 0 .75rem}.join-benefits ul{list-style:none;padding:0;margin:0}.join-benefits ul li{padding:.4rem 0;font-size:.9rem;color:#374151}.join-actions{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.btn-join-primary{display:block;padding:.8rem;border-radius:12px;background:#22c55e;color:#fff;font-weight:700;font-size:1rem;text-decoration:none;transition:transform .15s,box-shadow .15s}.btn-join-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px #22c55e4d}.btn-join-secondary{display:block;padding:.6rem;border-radius:12px;border:1px solid #e2e8f0;color:#6b7280;font-weight:600;font-size:.9rem;text-decoration:none;transition:border-color .15s}.btn-join-secondary:hover{border-color:#22c55e;color:#22c55e}.join-note{font-size:.8rem;color:#9ca3af}@media(max-width:500px){.join-card{padding:1.5rem}.join-card h1{font-size:1.3rem}}.user-management{padding:1.5rem;max-width:1200px;margin:0 auto}.um-header{margin-bottom:1.5rem}.um-header h1{font-size:1.75rem;margin:0 0 .25rem;color:var(--text-primary, #333)}.um-header .um-subtitle{color:var(--text-secondary, #666);margin:0}.um-global-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin-bottom:1.5rem}.global-stat-card{display:flex;flex-direction:column;align-items:center;padding:1rem .5rem;background:var(--card-bg, white);border-radius:12px;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .2s}.global-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.global-stat-card .global-stat-icon{font-size:1.5rem;margin-bottom:.25rem}.global-stat-card .global-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #333)}.global-stat-card .global-stat-label{font-size:.8rem;color:var(--text-secondary, #888);margin-top:.15rem}.um-toolbar{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.um-search{display:flex;align-items:center;background:var(--card-bg, white);border:1px solid var(--border-color, #ddd);border-radius:8px;padding:.5rem .75rem;flex:1;min-width:200px}.um-search .search-icon{margin-right:.5rem}.um-search input{border:none;outline:none;background:transparent;flex:1;font-size:.95rem;color:var(--text-primary, #333)}.um-search .search-clear{background:none;border:none;cursor:pointer;color:var(--text-secondary, #888);font-size:1rem;padding:0 .25rem}.um-filters{display:flex;gap:.5rem}.um-filters .filter-btn{padding:.5rem 1rem;border:1px solid var(--border-color, #ddd);border-radius:8px;background:var(--card-bg, white);color:var(--text-secondary, #666);cursor:pointer;font-size:.85rem;transition:all .2s}.um-filters .filter-btn.active{background:#4caf50;color:#fff;border-color:#4caf50}.um-table-wrapper{overflow-x:auto;border-radius:12px;box-shadow:0 2px 8px #00000014}@media(max-width:768px){.um-table-wrapper{display:none}}.um-table{width:100%;border-collapse:collapse;background:var(--card-bg, white)}.um-table thead{background:#4caf50;color:#fff}.um-table thead th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.85rem;white-space:nowrap}.um-table tbody tr{border-bottom:1px solid var(--border-color, #f0f0f0);transition:background .15s}.um-table tbody tr:hover{background:var(--bg-secondary, #f9f9f9)}.um-table tbody tr.row--blocked{opacity:.6}.um-table td{padding:.6rem 1rem;font-size:.9rem;color:var(--text-primary, #333)}.um-table .td-id{font-weight:600;color:var(--text-secondary, #888);font-size:.85rem}.um-table .td-email{color:var(--text-secondary, #666);font-size:.85rem}.um-table .td-date{color:var(--text-secondary, #888);font-size:.85rem;white-space:nowrap}.um-table .user-cell{display:flex;align-items:center;gap:.5rem}.um-table .user-cell .user-avatar{font-size:1.25rem}.um-table .user-cell .user-name{font-weight:500}.um-table .td-actions{display:flex;gap:.4rem}.action-btn{background:none;border:1px solid transparent;border-radius:6px;cursor:pointer;padding:.3rem .5rem;font-size:1rem;transition:all .2s}.action-btn:hover{background:var(--bg-secondary, #f0f0f0);border-color:var(--border-color, #ddd)}.action-btn--danger:hover{background:#ffebee;border-color:#e53935}.action-btn--success:hover{background:#e8f5e9;border-color:#4caf50}.um-cards{display:none}@media(max-width:768px){.um-cards{display:flex;flex-direction:column;gap:.75rem}}.um-card{background:var(--card-bg, white);border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.um-card--blocked{opacity:.6}.um-card .um-card-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border-color, #f0f0f0)}.um-card .um-card-user{display:flex;align-items:center;gap:.5rem}.um-card .um-card-user .user-avatar{font-size:1.5rem}.um-card .um-card-user strong{display:block;font-size:.95rem}.um-card .um-card-user small{color:var(--text-secondary, #888);font-size:.8rem}.um-card .um-card-badges{display:flex;gap:.4rem;flex-wrap:wrap}.um-card .um-card-body{padding:.75rem 1rem}.um-card .um-card-body .um-card-email{margin:0 0 .25rem;font-size:.85rem;color:var(--text-secondary, #666)}.um-card .um-card-body .um-card-date{margin:0;font-size:.8rem;color:var(--text-secondary, #999)}.um-card .um-card-actions{display:flex;flex-wrap:wrap;gap:.4rem;padding:.5rem 1rem .75rem;border-top:1px solid var(--border-color, #f0f0f0)}.um-card .um-card-actions button{flex:1;min-width:fit-content;padding:.4rem .6rem;border:1px solid var(--border-color, #ddd);border-radius:6px;background:var(--card-bg, white);font-size:.8rem;cursor:pointer;transition:background .2s}.um-card .um-card-actions button:hover{background:var(--bg-secondary, #f0f0f0)}.um-empty{text-align:center;padding:3rem;color:var(--text-secondary, #888)}.user-detail{padding:1.5rem;max-width:900px;margin:0 auto}.ud-back{display:inline-flex;align-items:center;gap:.25rem;background:none;border:none;color:#4caf50;font-size:.95rem;font-weight:500;cursor:pointer;padding:.5rem 0;margin-bottom:1rem}.ud-back:hover{text-decoration:underline}.ud-header{display:flex;align-items:center;gap:1.25rem;padding:1.5rem;background:var(--card-bg, white);border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:1.5rem}.ud-header .ud-avatar{font-size:3rem;width:64px;height:64px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary, #f5f5f5);border-radius:50%}.ud-header .ud-info{flex:1}.ud-header .ud-info h1{font-size:1.5rem;margin:0 0 .2rem;color:var(--text-primary, #333)}.ud-header .ud-info .ud-email{margin:0 0 .5rem;color:var(--text-secondary, #666);font-size:.9rem}.ud-header .ud-info .ud-badges{display:flex;gap:.5rem}.badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600;white-space:nowrap}.badge--active{background:#e8f5e9;color:#2e7d32}.badge--blocked{background:#ffebee;color:#c62828}.badge--vip{background:linear-gradient(135deg,#fff8e1,#ffe082);color:#f57f17}.badge--premium{background:linear-gradient(135deg,#e8eaf6,#9fa8da);color:#283593}.badge--free{background:#f1f8e9;color:#558b2f}.ud-section{margin-bottom:1.5rem}.ud-section h2{font-size:1.15rem;margin:0 0 1rem;color:var(--text-primary, #333)}.ud-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;background:var(--card-bg, white);border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #00000014}.ud-info-grid .info-item{display:flex;flex-direction:column;gap:.2rem}.ud-info-grid .info-item .info-label{font-size:.75rem;color:var(--text-secondary, #888);text-transform:uppercase;letter-spacing:.5px}.ud-info-grid .info-item .info-value{font-size:.95rem;font-weight:500;color:var(--text-primary, #333)}.ud-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.stat-card{display:flex;flex-direction:column;align-items:center;padding:1.25rem .75rem;background:var(--card-bg, white);border-radius:12px;box-shadow:0 2px 8px #00000014}.stat-card .stat-icon{font-size:1.5rem;margin-bottom:.4rem}.stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary, #333)}.stat-card .stat-label{font-size:.8rem;color:var(--text-secondary, #888);margin-top:.15rem}.stat-card--gardens{border-top:3px solid #4caf50}.stat-card--observations{border-top:3px solid #2196f3}.stat-card--seeds{border-top:3px solid #ff9800}.stat-card--events{border-top:3px solid #9c27b0}.ud-actions{display:flex;flex-wrap:wrap;gap:.75rem}.ud-action-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.65rem 1.25rem;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.ud-action-btn--primary{background:#e3f2fd;color:#1565c0}.ud-action-btn--primary:hover{background:#bbdefb}.ud-action-btn--success{background:#e8f5e9;color:#2e7d32}.ud-action-btn--success:hover{background:#c8e6c9}.ud-action-btn--warning{background:#fff3e0;color:#e65100}.ud-action-btn--warning:hover{background:#ffe0b2}.ud-action-btn--danger{background:#ffebee;color:#c62828}.ud-action-btn--danger:hover{background:#ffcdd2}.admin-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;gap:1rem}.admin-loading .spinner{width:40px;height:40px;border:3px solid var(--border-color, #ddd);border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite}.ud-error{text-align:center;padding:3rem}.ud-error h2{margin-bottom:1rem}.ud-error button{background:#4caf50;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:8px;cursor:pointer}@media(max-width:600px){.ud-header{flex-direction:column;text-align:center}.ud-badges{justify-content:center}.ud-actions{flex-direction:column}.ud-action-btn{width:100%;justify-content:center}}.public-profile{max-width:700px;margin:0 auto;padding:1.5rem 1rem}.public-profile__loading,.public-profile__error{text-align:center;padding:3rem;color:var(--text-secondary, #888)}.public-profile__back{background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--primary, #4caf50);margin-bottom:1rem;padding:0}.public-profile__back:hover{text-decoration:underline}.public-profile__card{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.public-profile__header{display:flex;align-items:center;gap:1.25rem}.public-profile__avatar{width:80px;height:80px;border-radius:50%;object-fit:cover;flex-shrink:0}.public-profile__avatar--placeholder{display:flex;align-items:center;justify-content:center;background:var(--primary, #4caf50);color:#fff;font-size:2rem;font-weight:600}.public-profile__info{display:flex;flex-direction:column;gap:.25rem}.public-profile__info h1{margin:0;font-size:1.4rem}.public-profile__exp{font-size:.85rem;color:var(--primary, #4caf50);font-weight:500}.public-profile__city,.public-profile__member{font-size:.8rem;color:var(--text-secondary, #888)}.public-profile__bio{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border, #eee)}.public-profile__bio p{margin:0;color:var(--text-primary, #333);line-height:1.5}.public-profile__section{background:var(--bg-card, #fff);border:1px solid var(--border, #e0e0e0);border-radius:12px;padding:1.25rem;margin-bottom:1rem}.public-profile__section h2{margin:0 0 1rem;font-size:1.1rem}.public-profile__stats{display:flex;gap:2rem}.public-profile__stat{display:flex;flex-direction:column;align-items:center}.public-profile__stat-value{font-size:1.5rem;font-weight:700;color:var(--primary, #4caf50)}.public-profile__stat-label{font-size:.8rem;color:var(--text-secondary, #888)}.public-profile__gardens{display:flex;flex-direction:column;gap:.5rem}.public-profile__garden{display:flex;gap:.75rem;align-items:center;padding:.6rem;background:var(--bg-hover, #f9f9f9);border-radius:8px;font-size:.85rem}.public-profile__garden-name{font-weight:600}.public-profile__garden-type{color:var(--text-secondary, #888)}.public-profile__actions{margin-top:1rem}.public-profile__msg-hint{text-align:center;color:var(--text-secondary, #888);font-size:.85rem;font-style:italic}.public-profile__msg-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.7rem 1rem;background:var(--primary, #4caf50);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity .2s}.public-profile__msg-btn:hover{opacity:.9}.public-profile__msg-btn:disabled{opacity:.5;cursor:not-allowed}.soil-analysis{max-width:800px;margin:0 auto;padding:1.5rem}.soil-intro{text-align:center}.soil-intro__hero{margin-bottom:2rem}.soil-intro__emoji{font-size:3.5rem;display:block;margin-bottom:.5rem}.soil-intro h1{font-size:2rem;margin-bottom:.5rem;color:var(--text-primary)}.soil-intro__subtitle{color:var(--text-secondary);font-size:1rem;max-width:500px;margin:0 auto;line-height:1.6}.soil-intro__phases{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}@media(max-width:600px){.soil-intro__phases{grid-template-columns:1fr}}.soil-intro__phase-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;text-align:left}.soil-intro__phase-card .phase-icon{font-size:2rem}.soil-intro__phase-card h3{font-size:1rem;margin:.5rem 0 .25rem}.soil-intro__phase-card p{color:var(--text-secondary);font-size:.875rem;margin-bottom:.5rem}.soil-intro__phase-card .phase-duration{font-size:.75rem;color:var(--text-tertiary)}.soil-intro__existing{display:flex;align-items:center;justify-content:space-between;background:var(--bg-secondary);border-radius:var(--radius-lg);padding:1rem 1.5rem;margin-bottom:2rem}.soil-intro__existing-badge{display:flex;align-items:center;gap:.75rem;text-align:left}.soil-intro__existing-badge>span:first-child{font-size:2rem}.soil-intro__existing-badge strong{display:block;font-size:.95rem}.soil-intro__existing-badge .confidence{font-size:.8rem;color:var(--text-secondary)}.soil-intro__actions .btn{font-size:1.1rem;padding:.875rem 2rem}.soil-intro__actions .btn:disabled{opacity:.5;cursor:not-allowed}.soil-intro__garden-select{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;margin-bottom:1.5rem;text-align:left}.soil-intro__garden-select h3{margin-bottom:1rem;font-size:1.1rem}.soil-intro__no-gardens{color:var(--text-secondary);text-align:center;padding:1rem}.soil-intro__gardens-grid{display:flex;flex-direction:column;gap:.5rem}.soil-garden-card{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:var(--bg-secondary);border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;text-align:left;position:relative}.soil-garden-card:hover{border-color:var(--primary);background:var(--primary-light)}[data-theme=dark] .soil-garden-card:hover{background:#22c55e14}.soil-garden-card--selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 1px var(--primary)}[data-theme=dark] .soil-garden-card--selected{background:#22c55e1f}.soil-garden-card--analyzed .soil-garden-card__icon{opacity:1}.soil-garden-card__main{display:flex;align-items:center;gap:.625rem;flex:1;min-width:0}.soil-garden-card__icon{font-size:1.5rem;flex-shrink:0}.soil-garden-card__info{min-width:0}.soil-garden-card__info strong{display:block;font-size:.95rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.soil-garden-card__meta{font-size:.75rem;color:var(--text-tertiary)}.soil-garden-card__badge{display:flex;align-items:center;gap:.25rem;font-size:.75rem;padding:.25rem .5rem;border-radius:var(--radius-sm);background:var(--primary-light);color:var(--primary-dark);flex-shrink:0}[data-theme=dark] .soil-garden-card__badge{background:#22c55e26;color:#86efac}.soil-garden-card__badge--new{background:var(--bg-tertiary);color:var(--text-tertiary);font-style:italic}[data-theme=dark] .soil-garden-card__badge--new{background:#ffffff0f;color:var(--text-tertiary)}.soil-garden-card__badge-text{white-space:nowrap}.soil-garden-card__check{position:absolute;right:.75rem;color:var(--primary);font-weight:700;font-size:1.1rem}.soil-wizard__garden-tag{display:inline-flex;align-items:center;gap:.375rem;font-size:.8rem;padding:.25rem .75rem;margin-bottom:.75rem;background:var(--primary-light);color:var(--primary-dark);border-radius:var(--radius-full, 9999px)}[data-theme=dark] .soil-wizard__garden-tag{background:#22c55e1f;color:#86efac}.soil-wizard__progress{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.soil-wizard__progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.soil-wizard__progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .3s ease}.soil-wizard__step-label{font-size:.8rem;color:var(--text-tertiary);font-weight:600;white-space:nowrap}.soil-wizard__question{margin-bottom:1.5rem}.soil-wizard__question h2{font-size:1.5rem;margin-bottom:.5rem}.soil-wizard__description{color:var(--text-secondary);line-height:1.6}.soil-wizard__tip{display:flex;gap:.5rem;background:var(--warning-light);border-radius:var(--radius-md);padding:.75rem 1rem;margin-top:.75rem;font-size:.875rem;color:var(--warning-dark)}[data-theme=dark] .soil-wizard__tip{background:#f59e0b1f;color:#fbbf24}.soil-wizard__tip>span{flex-shrink:0}.soil-wizard__tip>p{margin:0}.soil-wizard__options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.soil-wizard__option{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--card-bg);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;text-align:left;width:100%}.soil-wizard__option:hover{border-color:var(--primary);background:var(--primary-light)}[data-theme=dark] .soil-wizard__option:hover{background:#22c55e14}.soil-wizard__option--selected{border-color:var(--primary);background:var(--primary-light);box-shadow:0 0 0 1px var(--primary)}[data-theme=dark] .soil-wizard__option--selected{background:#22c55e1f}.soil-wizard__option-icon{font-size:1.5rem;flex-shrink:0;width:2rem;text-align:center}.soil-wizard__option-content{flex:1}.soil-wizard__option-content strong{display:block;font-size:.95rem;color:var(--text-primary)}.soil-wizard__option-hint{font-size:.8rem;color:var(--text-tertiary)}.soil-wizard__option-check{color:var(--primary);font-weight:700;font-size:1.2rem}.soil-wizard__multi-hint{text-align:center;color:var(--text-tertiary);font-size:.8rem;font-style:italic;margin-bottom:1rem}.soil-wizard__nav{display:flex;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.soil-result-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;margin-bottom:1.5rem}.soil-result-card__header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.soil-result-card__header h2{margin:0}.soil-result-card__emoji{font-size:2.5rem}.soil-result-card__subtype{font-size:.85rem;color:var(--text-secondary);font-style:italic}.soil-result-card__description{color:var(--text-secondary);line-height:1.6;margin-bottom:1.25rem}.soil-result-card__metrics{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.25rem}.soil-result-card__granulometry{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}.soil-result-card__granulometry h4{margin-bottom:.75rem}.soil-result-card__scores{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border-color)}.soil-result-card__scores h4{margin-bottom:.75rem}.soil-result-card__tests-badge{display:inline-block;margin-top:1rem;padding:.375rem .75rem;background:var(--info-light);color:var(--info-dark);border-radius:var(--radius-md);font-size:.8rem;font-weight:600}[data-theme=dark] .soil-result-card__tests-badge{background:#3b82f626;color:#60a5fa}.soil-metric{display:flex;align-items:center;gap:.75rem}.soil-metric__label{width:80px;font-size:.8rem;color:var(--text-secondary);flex-shrink:0}.soil-metric__bar{flex:1;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.soil-metric__fill{height:100%;border-radius:4px;transition:width .5s ease}.soil-metric__fill--confidence-high{background:var(--success)}.soil-metric__fill--confidence-mid{background:var(--warning)}.soil-metric__fill--confidence-low{background:var(--danger)}.soil-metric__ph{flex:1;height:8px;position:relative}.soil-metric__ph-scale{width:100%;height:100%;border-radius:4px;background:linear-gradient(to right,#ef4444,#f59e0b 30%,#22c55e 45% 55%,#3b82f6 70%,#6366f1)}.soil-metric__ph-marker{position:absolute;top:-3px;width:4px;height:14px;background:var(--text-primary);border-radius:2px;transform:translate(-50%);z-index:1}.soil-metric__value{font-weight:700;font-size:.9rem;min-width:40px;text-align:right}.soil-metric__value--text{min-width:auto;font-size:.85rem}.granulo-bars{display:flex;flex-direction:column;gap:.5rem}.granulo-bar{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.granulo-bar>span:first-child{width:80px;flex-shrink:0}.granulo-bar>span:last-child{width:40px;text-align:right;font-weight:600}.granulo-bar__track{flex:1;height:10px;background:var(--bg-tertiary);border-radius:5px;overflow:hidden}.granulo-bar__fill{height:100%;border-radius:5px;transition:width .5s ease}.granulo-bar__fill--sand{background:#d97706}.granulo-bar__fill--silt{background:#65a30d}.granulo-bar__fill--clay{background:#b45309}.score-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem}.score-row__label{width:130px;font-size:.85rem;flex-shrink:0}.score-row__bar{flex:1;height:10px;background:var(--bg-tertiary);border-radius:5px;overflow:hidden}.score-row__fill{height:100%;border-radius:5px;transition:width .5s ease}.score-row__value{width:30px;text-align:right;font-weight:700;font-size:.85rem}.soil-result__next{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;text-align:center}.soil-result__next h3{margin-bottom:.5rem}.soil-result__next p{color:var(--text-secondary);margin-bottom:1.25rem;max-width:500px;margin-left:auto;margin-right:auto}.soil-result__next-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.soil-home-tests__header{margin-bottom:1.5rem}.soil-home-tests__header h2{margin-bottom:.25rem}.soil-home-tests__header p{color:var(--text-secondary)}.soil-home-tests__grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}@media(max-width:600px){.soil-home-tests__grid{grid-template-columns:1fr}}.soil-home-tests__actions{display:flex;flex-direction:column;align-items:center;gap:.75rem}.soil-test-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;transition:all .2s ease}.soil-test-card--done{border-color:var(--success);background:#22c55e08}[data-theme=dark] .soil-test-card--done{background:#22c55e0f}.soil-test-card__header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.5rem}.soil-test-card__header h3{font-size:.95rem;margin:0}.soil-test-card__emoji{font-size:1.8rem;flex-shrink:0}.soil-test-card__meta{display:flex;gap:.75rem;font-size:.75rem;color:var(--text-tertiary);margin-top:.25rem}.soil-test-card__check{margin-left:auto;font-size:1.2rem}.soil-test-card>p{font-size:.85rem;color:var(--text-secondary);margin-bottom:.75rem;line-height:1.5}.home-test-runner{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem}.home-test-runner__header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.home-test-runner__header>span:first-child{font-size:1.8rem}.home-test-runner__header h2{flex:1;margin:0;font-size:1.25rem}.home-test-runner__materials{background:var(--bg-secondary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.25rem}.home-test-runner__materials h4{margin-bottom:.5rem}.home-test-runner__materials ul{list-style:none;padding:0;margin:0}.home-test-runner__materials ul li{padding:.25rem 0;font-size:.9rem;color:var(--text-secondary)}.home-test-runner__materials ul li:before{content:"• ";color:var(--primary);font-weight:700}.home-test-runner__step{margin-bottom:1.25rem}.home-test-runner__step-number{font-size:.75rem;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.75rem}.home-test-runner__step-content{display:flex;gap:1rem;align-items:flex-start}.home-test-runner__step-content h3{margin:0 0 .25rem;font-size:1.1rem}.home-test-runner__step-content p{color:var(--text-secondary);line-height:1.6;margin:0}.home-test-runner__step-icon{font-size:2rem;flex-shrink:0}.home-test-runner__timer{margin-top:1rem;text-align:center}.home-test-runner__timer .timer-running{display:flex;flex-direction:column;align-items:center;gap:.5rem}.home-test-runner__timer .timer-circle{width:80px;height:80px;border-radius:50%;border:3px solid var(--primary);display:flex;align-items:center;justify-content:center}.home-test-runner__timer .timer-value{font-size:1.1rem;font-weight:700;color:var(--primary)}.home-test-runner__timer .timer-label{font-size:.85rem;color:var(--text-secondary)}.home-test-runner__input h3{margin-bottom:.25rem}.home-test-runner__input>p{color:var(--text-secondary);margin-bottom:1rem}.home-test-runner__fields{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.25rem}.home-test-runner__field label{display:flex;align-items:center;gap:.375rem;font-size:.9rem;font-weight:600;margin-bottom:.375rem}.home-test-runner__field .form-input{width:100%;padding:.625rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.9rem;background:var(--card-bg);color:var(--text-primary);transition:border-color .2s}.home-test-runner__field .form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #22c55e26}.home-test-runner__field select.form-input{cursor:pointer}.home-test-runner__nav{display:flex;justify-content:space-between;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.triangle-textural{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:1.5rem;margin-bottom:1.5rem;text-align:center}.triangle-textural h3{margin-bottom:.25rem}.triangle-textural__subtitle{color:var(--text-secondary);font-size:.85rem;margin-bottom:1rem}.triangle-textural__svg{max-width:320px;margin:0 auto}.triangle-textural__svg .triangle-label{font-size:10px;fill:var(--text-primary);font-weight:600}.triangle-textural__svg .triangle-zone-label{font-size:9px;fill:var(--success);font-weight:600;font-style:italic}.soil-recommendations{margin-bottom:1.5rem}.soil-recommendations>h2{margin-bottom:1.25rem}.soil-rec__section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem}.soil-rec__section h3{font-size:1rem;margin-bottom:.75rem}.soil-rec__section ul{list-style:none;padding:0;margin:0}.soil-rec__section ul li{padding:.3rem 0;font-size:.9rem;color:var(--text-secondary)}.soil-rec__section ul li:before{content:"→ ";color:var(--primary)}.soil-amendments-grid{display:flex;flex-direction:column;gap:.75rem}.soil-amendment-card{display:flex;gap:.75rem;align-items:flex-start;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.soil-amendment-card__icon{font-size:1.5rem;flex-shrink:0}.soil-amendment-card strong{display:block;font-size:.9rem}.soil-amendment-card .dose{display:inline-block;font-size:.75rem;color:var(--primary-dark);background:var(--primary-light);padding:.1rem .4rem;border-radius:var(--radius-sm);margin-left:.375rem}[data-theme=dark] .soil-amendment-card .dose{background:#22c55e26;color:#86efac}.soil-amendment-card p{font-size:.8rem;color:var(--text-secondary);margin-top:.25rem}.soil-crops-tags{display:flex;flex-wrap:wrap;gap:.5rem}.soil-crop-tag{padding:.375rem .75rem;border-radius:var(--radius-md);font-size:.8rem;font-weight:600}.soil-crop-tag--ideal{background:var(--primary-light);color:var(--primary-dark)}[data-theme=dark] .soil-crop-tag--ideal{background:#22c55e26;color:#86efac}.soil-crop-tag--avoid{background:#ef444414;color:var(--danger)}[data-theme=dark] .soil-crop-tag--avoid{background:#ef444426;color:#fca5a5}.soil-final__actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}:root{--primary: #22c55e;--primary-dark: #16a34a;--primary-light: #dcfce7;--secondary: #3b82f6;--secondary-dark: #2563eb;--secondary-light: #dbeafe;--success: #22c55e;--warning: #f59e0b;--warning-light: #fef3c7;--warning-dark: #d97706;--danger: #ef4444;--info: #3b82f6;--info-light: #dbeafe;--info-dark: #1d4ed8;--bg-primary: #f9fafb;--bg-secondary: #f3f4f6;--bg-tertiary: #e5e7eb;--card-bg: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--border-color: #e5e7eb;--border-color-light: #f3f4f6;--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);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--navbar-height: 64px;--sidebar-width: 210px;--sidebar-collapsed-width: 70px;--transition-fast: .15s;--transition-base: .2s;--transition-slow: .3s}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--card-bg: #1e293b;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--border-color: #334155;--border-color-light: #1e293b}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;font-size:16px}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:700}.card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-sm);transition:all var(--transition-base) ease}.card:hover{box-shadow:var(--shadow-md)}.card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.card__title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all var(--transition-base) ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn--secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--primary)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--ghost{background:transparent;color:var(--text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--bg-secondary);color:var(--text-primary)}.btn--block{width:100%}.btn--sm{padding:.5rem 1rem;font-size:.8125rem}.btn--lg{padding:.875rem 1.5rem;font-size:1rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .875rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-primary);transition:all var(--transition-base) ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-input::placeholder,.form-select::placeholder,.form-textarea::placeholder{color:var(--text-tertiary)}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{opacity:.6;cursor:not-allowed}.form-textarea{resize:vertical;min-height:100px}.form-error{display:block;margin-top:.375rem;font-size:.8125rem;color:var(--danger)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:600;border-radius:999px;white-space:nowrap}.badge--primary{background:var(--primary-light);color:var(--primary-dark)}.badge--secondary{background:var(--secondary-light);color:var(--secondary-dark)}.badge--success{background:#dcfce7;color:#166534}.badge--warning{background:var(--warning-light);color:var(--warning-dark)}.badge--danger{background:#fee2e2;color:#991b1b}.text-primary{color:var(--primary)}.text-secondary{color:var(--secondary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.spinner{display:inline-block;width:1.5rem;height:1.5rem;border:3px solid var(--border-color);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}
