@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes spin{to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;background:linear-gradient(135deg,#2e7d32 0,#4caf50 100%);min-height:100vh;color:#333}.app-container{width:100%;max-width:414px;margin:0 auto;background:#fff;min-height:100vh;box-shadow:0 0 20px rgba(0,0,0,.2);position:relative;padding-bottom:80px}@media (min-width:576px){.app-container{max-width:600px;margin:20px auto;min-height:calc(100vh - 40px);border-radius:12px;overflow:hidden}}@media (min-width:768px){.app-container{max-width:720px}}@media (min-width:1024px){.app-container{max-width:1200px;padding-bottom:20px}body{padding:20px 0}}.header{background:linear-gradient(135deg,#2e7d32,#4caf50);color:#fff;padding:20px;text-align:center;position:relative}@media (min-width:768px){.header{padding:30px}}@media (min-width:1024px){.header{padding:40px;text-align:left;display:flex;justify-content:space-between;align-items:center}}.install-btn,.login-btn,.user-info{position:absolute;top:15px;border:1px solid rgba(255,255,255,.3)}.install-btn{right:15px;background:rgba(255,255,255,.2);color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;cursor:pointer;display:none}.login-btn,.user-info{left:15px}.user-info{background:rgba(255,255,255,.2);color:#fff;padding:4px 8px;border-radius:4px;font-size:11px}.login-btn{background:rgba(255,255,255,.9);color:#2e7d32;padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;font-weight:600}.weather-card{background:linear-gradient(135deg,#81c784,#a5d6a7);margin:20px;padding:20px;border-radius:12px;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.1)}@media (min-width:768px){.weather-card{margin:30px;padding:30px}}@media (min-width:1024px){.weather-card{margin:40px;padding:40px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}}@media (min-width:768px){.current-temp{font-size:3em}}@media (min-width:1024px){.current-temp{font-size:4em}}.weather-details{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:15px}@media (min-width:768px){.weather-details{grid-template-columns:repeat(4,1fr);gap:15px}}.detail-item{text-align:center;background:rgba(255,255,255,.2);padding:8px;border-radius:8px;font-size:14px}.community-features{padding:0 20px;margin-bottom:20px}@media (min-width:768px){.community-features{padding:0 30px;margin-bottom:30px}}@media (min-width:1024px){.community-features{padding:0 40px;margin-bottom:40px}}.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:15px}@media (min-width:576px){.features-grid{grid-template-columns:repeat(3,1fr);gap:20px}}@media (min-width:768px){.features-grid{grid-template-columns:repeat(3,1fr);gap:25px}}@media (min-width:1024px){.features-grid{grid-template-columns:repeat(4,1fr);gap:30px}}.feature-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.1)}.feature-card:hover{border-color:#4caf50;transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.15)}.feature-card.premium{border-color:gold;background:linear-gradient(135deg,#fff9e6,#fff)}.feature-icon{font-size:2.5em;margin-bottom:10px;display:block}.feature-title{font-weight:600;margin-bottom:5px;color:#333}.feature-subtitle{font-size:12px;color:#666;line-height:1.3}.premium-badge{display:inline-block;background:gold;color:#333;padding:2px 6px;border-radius:4px;font-size:9px;font-weight:700;margin-top:5px}.tabs{display:flex;background:#f5f5f5;margin:0 20px;border-radius:8px;overflow:hidden}.tab{flex:1;padding:12px;background:0 0;border:0;cursor:pointer;font-size:14px;transition:all .3s}.tab.active{background:#4caf50;color:#fff}.content{padding:20px;min-height:300px}@media (min-width:768px){.content{padding:30px}}@media (min-width:1024px){.content{padding:40px;display:grid;grid-template-columns:1fr;gap:30px}.content.multi-column{grid-template-columns:repeat(2,1fr)}}.content-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:15px;margin:15px 0;box-shadow:0 2px 8px rgba(0,0,0,.1)}@media (min-width:768px){.content-card{padding:20px;margin:20px 0}}@media (min-width:1024px){.content-card{padding:25px;margin:0;transition:transform .2s ease}.content-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px rgba(0,0,0,.15)}}.event-card{border-left:4px solid #2196f3}.business-card{border-left:4px solid #ff9800}.garden-card{border-left:4px solid #4caf50}.business-category,.event-date{color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;display:inline-block;margin-bottom:8px}.event-date{background:#2196f3}.business-category{background:#ff9800}.card-title{font-weight:600;margin-bottom:8px;color:#333}.card-content{color:#666;line-height:1.4;font-size:14px}.card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:10px;font-size:12px;color:#999}.bottom-nav{position:fixed!important;bottom:0;left:0;right:0;width:100%;background:#fff;border-top:1px solid #e0e0e0;display:flex!important;box-shadow:0-2px 10px rgba(0,0,0,.1);z-index:1000}.nav-item{flex:1;padding:12px;text-align:center;background:0 0;border:0;cursor:pointer;transition:background .3s}@media (min-width:768px){.nav-item{padding:16px}}@media (min-width:1024px){.nav-item{display:flex;align-items:center;justify-content:center;gap:8px;padding:20px}}.nav-item.active{background:#e8f5e8;color:#2e7d32}.nav-icon{font-size:18px;margin-bottom:2px}@media (min-width:768px){.nav-icon{font-size:20px}}@media (min-width:1024px){.nav-icon{font-size:24px;margin-bottom:0}}.nav-label{font-size:10px;font-weight:500}@media (min-width:768px){.nav-label{font-size:12px}}@media (min-width:1024px){.nav-label{font-size:14px}}.hidden{display:none}.search-bar{background:#f5f5f5;border:1px solid #ddd;border-radius:25px;padding:12px 20px;margin:15px 0;font-size:14px;width:100%}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.section-title,.view-all{font-size:18px;font-weight:600;color:#333}.view-all{color:#4caf50;font-size:12px;text-decoration:none}.login-modal,.offline-indicator{position:fixed;top:0;display:none}.offline-indicator{left:50%;transform:translateX(-50%);background:#ff9800;color:#fff;padding:8px 16px;border-radius:0 0 8px 8px;font-size:12px;z-index:1000}.login-modal{left:0;width:100%;height:100%;background:rgba(0,0,0,.8);align-items:center;justify-content:center;z-index:9999;padding:20px}.login-form{background:#fff;padding:30px;border-radius:12px;width:90%;max-width:350px;box-shadow:0 4px 20px rgba(0,0,0,.3);position:relative}@media (min-width:768px){.login-form{max-width:450px;padding:40px}}@media (min-width:1024px){.login-form{max-width:500px;padding:50px}}.data-error p,.form-group{margin-bottom:15px}.form-btn,.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px}.form-btn{background:linear-gradient(135deg,#2e7d32,#4caf50);color:#fff;border:0;cursor:pointer;margin-bottom:10px}.form-link{color:#4caf50;text-decoration:none;font-size:12px;text-align:center;display:block;margin-top:10px}.close-modal{position:absolute;top:10px;right:15px;background:0 0;border:0;font-size:24px;cursor:pointer;color:#999}.data-current{opacity:1}.data-recent{opacity:.9}.data-stale{opacity:.8;color:#ff9800!important}.data-old{opacity:.7;color:#f44336!important}.data-unavailable{opacity:.6;color:#757575!important}#weatherCondition{transition:all .3s ease;cursor:help}#weatherCondition:hover{transform:scale(1.02)}.stale-data-warning{background:linear-gradient(135deg,#fff3e0,#fff);border:1px solid #ff9800;border-radius:8px;padding:12px 16px;margin:10px 0;display:flex;align-items:center;gap:10px;font-size:13px;box-shadow:0 2px 8px rgba(255,152,0,.1)}.warning-icon{font-size:16px;color:#ff9800}.warning-text{flex:1;color:#e65100;font-weight:500}.warning-refresh-btn{background:#ff9800;color:#fff;border:0;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.warning-refresh-btn:hover{background:#f57c00}.data-error{background:linear-gradient(135deg,#ffebee,#fff);border:2px solid #f44336;border-radius:12px;padding:20px;margin:20px;text-align:center;box-shadow:0 4px 12px rgba(244,67,54,.1)}.data-error h3{color:#f44336;margin-bottom:10px;font-size:18px}.data-error p{color:#666;line-height:1.5}.refresh-btn{background:linear-gradient(135deg,#f44336,#e53935);font-weight:600}.refresh-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(244,67,54,.3)}.event-category-badge,.event-status-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:10px}.event-status-badge{font-weight:700;margin-left:8px;text-transform:uppercase}.event-status-badge.live{background:#4caf50;color:#fff;animation:pulse 2s infinite}.event-status-badge.today{background:#ff9800;color:#fff}.event-category-badge{background:#e3f2fd;color:#1976d2;margin:2px 4px 2px 0;font-weight:500}.event-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;flex-wrap:wrap}.event-subtitle{font-size:14px;color:#666;font-style:italic;margin-bottom:8px}.event-full-description{margin:12px 0;line-height:1.5}.event-full-description h1,.event-full-description h2,.event-full-description h3{margin:16px 0 8px;color:#333}.event-full-description p{margin-bottom:8px}.event-full-description ol,.event-full-description ul{margin:8px 0 8px 20px}.event-image{margin-bottom:12px;border-radius:8px;overflow:hidden}.event-image img{width:100%;height:auto;display:block}.content-card img,.event-card img,.event-full-description img{max-width:100%;height:auto;display:block;margin:10px auto;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.event-card{overflow:hidden;word-wrap:break-word;word-break:break-word}.event-card .wp-block-image,.event-card figure{margin:10px 0;text-align:center}.event-card figure img{max-width:100%;height:auto;object-fit:contain;max-height:300px}.event-card .wp-block-image img{max-width:100%;height:auto;border-radius:6px}.event-image-container{width:100%;overflow:hidden;margin:10px 0}.event-image-container img{max-width:100%;height:auto;display:block;margin:0 auto}.event-actions{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.event-link{display:inline-block;background:#2196f3;color:#fff;padding:6px 12px;border-radius:4px;text-decoration:none;font-size:12px;font-weight:500;transition:background .3s ease}.event-link:hover{background:#1976d2}.event-location,.event-organizer,.event-time{display:inline-block;margin-right:12px;font-size:12px;color:#666}.events-filters{background:#f5f5f5;padding:15px;border-radius:8px;margin-bottom:20px}.filter-group{margin-bottom:10px}.filter-group:last-child{margin-bottom:0}.filter-group select,.search-input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.refresh-btn,.search-btn,.view-all-btn{background:#2196f3;color:#fff;border:0;padding:8px 16px;border-radius:4px;font-size:14px;cursor:pointer;margin-top:8px;transition:background .3s ease}.refresh-btn:hover,.search-btn:hover,.view-all-btn:hover{background:#1976d2}.empty-state{text-align:center;padding:40px 20px;color:#666}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state-title{font-size:18px;font-weight:600;margin-bottom:8px;color:#333}.empty-state-message{margin-bottom:20px;line-height:1.5}.view-all-card{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;text-align:center}.view-all-card .card-title{color:#1976d2}.loading-state{opacity:.7}.loading-state .event-date{background:#f0f0f0;color:#999}@media (max-width:480px){.event-header{flex-direction:column}.event-category-badge{margin-bottom:4px}.events-filters{padding:10px}.event-actions{flex-direction:column}.event-link{text-align:center}}@media (min-width:768px){.events-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.event-card{margin:0}}@media (min-width:1024px){.events-grid{grid-template-columns:repeat(3,1fr);gap:30px}.event-full-description{font-size:16px;line-height:1.6}}.current-conditions{background:#fff;border-radius:12px;padding:20px;margin-bottom:16px;box-shadow:0 2px 8px rgba(0,0,0,.1);text-align:center;border-left:4px solid #4caf50}.current-conditions h3{margin:0 0 12px;color:#2e7d32;font-size:16px}.current-temp{font-size:48px;font-weight:700;color:#333;margin-bottom:4px}.current-feels{font-size:14px;color:#666;margin-bottom:8px}.current-condition{font-size:18px;color:#555;margin-bottom:16px}.current-details{display:flex;justify-content:center;gap:20px;font-size:14px;color:#666;flex-wrap:wrap}.current-details span{white-space:nowrap}.forecast-list{display:flex;flex-direction:column;gap:12px}.forecast-list.extended{max-height:600px;overflow-y:auto;padding-right:4px}.forecast-list.extended::-webkit-scrollbar{width:6px}.forecast-list.extended::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.forecast-list.extended::-webkit-scrollbar-thumb{background:#4caf50;border-radius:3px}.forecast-day{background:#fff;border-radius:8px;padding:16px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px rgba(0,0,0,.05);transition:all .2s}.forecast-day:hover{transform:translateY(-2px);box-shadow:0 4px 8px rgba(0,0,0,.1)}.forecast-day.extended-day{background:#f9f9f9}.forecast-day.no-data{opacity:.6}.forecast-day-info{flex:1}.forecast-date{font-weight:700;color:#2e7d32;margin-bottom:4px}.date-str{font-size:12px;color:#888;margin-left:8px;font-weight:400}.forecast-temp{font-size:18px;color:#333;margin-bottom:4px;font-weight:500}.forecast-conditions{color:#666;font-size:14px;margin-bottom:4px}.forecast-rain{font-size:12px;color:#2196f3}.forecast-details{font-size:12px;color:#888;margin-top:4px;display:flex;gap:8px;flex-wrap:wrap}.forecast-no-data{color:#999;font-size:14px;font-style:italic}.forecast-icon{font-size:36px;margin-left:16px}.premium-required{text-align:center;padding:40px 20px}.premium-icon{font-size:48px;margin-bottom:16px}.premium-required h3{color:#333;margin-bottom:12px}.premium-required p{color:#666;margin-bottom:20px}.premium-hint{color:#888;font-size:14px}.error,.loading{text-align:center;padding:40px;color:#666}.loading::after{content:"";display:inline-block;width:20px;height:20px;margin-left:10px;border:2px solid #4caf50;border-radius:50%;border-top-color:transparent;animation:spin 1s linear infinite}.error{background:#ffebee;color:#c62828;padding:16px;border-radius:8px;margin:16px 0}.inigo-container{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.coming-soon h4,.inigo-container h3{color:#2e7d32;margin-bottom:8px}.inigo-container p{color:#666;margin-bottom:16px}.coming-soon{text-align:center;padding:40px 20px}.coming-soon h4{color:#333}@media (max-width:360px){.current-temp{font-size:36px}.current-details{gap:10px;font-size:12px}.forecast-temp{font-size:16px}.forecast-icon{font-size:30px}}@media (min-width:768px){body{font-size:16px}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}}@media (min-width:1024px){body{font-size:18px}h1{font-size:3rem}h2{font-size:2.5rem}h3{font-size:2rem}h4{font-size:1.75rem}h5{font-size:1.5rem}h6{font-size:1.25rem}}.mobile-only{display:block}.desktop-only,.tablet-up{display:none}@media (min-width:768px){.mobile-only{display:none}.tablet-up{display:block}}@media (min-width:1024px){.desktop-only{display:block}}.responsive-padding{padding:20px}@media (min-width:768px){.responsive-padding{padding:30px}}@media (min-width:1024px){.responsive-padding{padding:40px}}@media (min-width:1440px){.app-container{max-width:1400px}.features-grid{grid-template-columns:repeat(6,1fr)}}
/* Shared header actions */
.app-header{background:linear-gradient(135deg,#2e7d32 0,#4caf50 100%);color:#fff;padding:16px;border-radius:12px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.app-title{font-size:24px;font-weight:700;display:flex;align-items:center;gap:8px}
.app-title-text{display:flex;flex-direction:column;line-height:1.1}
.app-title-subtitle{font-size:12px;font-weight:500;opacity:.85;margin-top:2px}
.app-title-icon{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(255,255,255,.2)}
.app-title-icon img{width:18px;height:18px;display:block;filter:brightness(0) invert(1)}
.header-buttons{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.header-btn{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.25);padding:8px 10px;border-radius:6px;color:#fff;cursor:pointer;transition:all .2s;font-size:13px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap;min-height:44px}
.header-btn:hover{background:rgba(255,255,255,.28)}
.header-btn .header-icon{width:16px;height:16px;display:block;filter:brightness(0) invert(1)}
.header-btn.install-btn{position:static;top:auto;right:auto;left:auto}
.chat-btn{display:inline-flex}
@media (min-width:768px){.app-header{padding:20px}.app-title{font-size:28px}}
@media (min-width:1024px){.app-header{padding:24px}.app-title{font-size:32px}}
@media (max-width:640px){.app-header{flex-wrap:wrap}.header-buttons{width:100%;justify-content:space-between}.header-btn{flex:1 1 calc(50% - 8px);justify-content:center}}
