.app{max-width:1200px;margin:0 auto;padding:2rem}header{text-align:center;margin-bottom:var(--space-12);padding:var(--space-8);background:var(--card-bg);border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}header h1{font-size:3rem;margin-bottom:var(--space-2);color:var(--text-primary);text-shadow:2px 2px 4px rgba(255,255,255,.5)}header p{font-size:1.2rem;color:var(--text-secondary)}.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;margin-top:2rem}.city-card{background:var(--card-bg);padding:var(--space-8);border-radius:12px;text-decoration:none;color:var(--text-primary);transition:transform var(--transition-base),background var(--transition-base),box-shadow var(--transition-base);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(112,92,83,.2);box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;gap:var(--space-3)}.city-card:hover{transform:translateY(-5px) scale(1.02);background:var(--card-bg-hover);box-shadow:0 12px 20px #0003;border-color:#705c5366}.city-icon{font-size:2.5rem;text-align:center;margin-bottom:var(--space-2)}.city-card h3{font-size:1.8rem;margin-bottom:var(--space-2);color:var(--text-primary);text-align:center}.city-details{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) 0;border-top:1px solid rgba(112,92,83,.2);border-bottom:1px solid rgba(112,92,83,.2)}.city-card .theme{font-size:1rem;color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-2)}.city-card .vibe{font-style:italic;color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-2)}.city-stats{display:flex;justify-content:center;gap:var(--space-4);margin-top:var(--space-2)}.stat{font-size:.9rem;color:var(--text-secondary);font-weight:600}.city{background:var(--card-bg);padding:var(--space-8);border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.back-link{color:var(--text-primary);text-decoration:none;display:inline-block;margin-bottom:var(--space-4);transition:color var(--transition-base);font-weight:600}.back-link:hover{color:var(--text-secondary)}.city h2{font-size:2.5rem;margin-bottom:var(--space-2);color:var(--text-primary)}.city-meta{color:var(--text-secondary);margin-bottom:var(--space-8)}.city-features{display:flex;gap:var(--space-6);margin-top:var(--space-8);justify-content:center;flex-wrap:wrap}.city-features section{background:#fffffff2;padding:var(--space-6);border-radius:12px;border:none;box-shadow:0 4px 12px #0000001a;flex:1 1 320px;max-width:400px;height:500px;display:flex;flex-direction:column;gap:var(--space-3)}.city-features h3{font-size:1.2rem;margin:0;color:var(--text-primary);text-align:center;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}button{background:var(--button-bg);color:var(--text-primary);border:2px solid var(--text-secondary);padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:600;transition:all var(--transition-base);font-family:var(--font-primary);width:100%}button:hover:not(:disabled){background:var(--button-bg-hover);transform:translateY(-2px);box-shadow:0 4px 8px #00000026}button:active:not(:disabled){transform:translateY(0)}button:disabled{opacity:.6;cursor:not-allowed}.ai-content{padding:var(--space-4);background:#fff9;border-radius:8px;line-height:1.5;color:var(--text-primary);animation:fadeIn var(--transition-slow) ease;font-size:.9rem;overflow-y:auto;flex:1;min-height:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading{text-align:center;padding:var(--space-12);font-size:1.2rem;color:var(--text-primary)}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-6);flex:1;min-height:200px}.spinner{width:35px;height:35px;border:3px solid rgba(112,92,83,.2);border-top-color:var(--text-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{color:var(--text-secondary);font-style:italic;font-size:.85rem}.error-message{padding:var(--space-4);background:#e74c3c1a;border:2px solid var(--error);border-radius:6px;color:var(--error);font-weight:600;font-size:.85rem;display:flex;align-items:center;justify-content:center;text-align:center;flex:1;min-height:200px}.public-square{background:linear-gradient(135deg,#ffe5d9,#fff5ee)!important;border-top:4px solid var(--public-square-accent)}.public-square h3{color:var(--public-square-accent);font-size:1.3rem}.public-square h3:before{content:"📢";font-size:2.5rem;display:block;margin-bottom:var(--space-2)}.radio{background:linear-gradient(135deg,#f3e5f5,#fcf4ff)!important;border-top:4px solid var(--radio-accent)}.radio h3{color:var(--radio-accent);font-size:1.3rem}.radio h3:before{content:"📻";font-size:2.5rem;display:block;margin-bottom:var(--space-2)}.newsletter{background:linear-gradient(135deg,#e3f2fd,#f0f8ff)!important;border-top:4px solid var(--newsletter-accent)}.newsletter h3{color:var(--newsletter-accent);font-size:1.3rem}.newsletter h3:before{content:"📰";font-size:2.5rem;display:block;margin-bottom:var(--space-2)}.empty-state{text-align:center;padding:var(--space-6);color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);flex:1;min-height:200px}.empty-state-icon{font-size:2.5rem;margin:0}.empty-state-message{font-size:1rem;margin:0;font-weight:600}.empty-state-hint{font-size:.85rem;font-style:italic;line-height:1.4;margin:0}.public-square-content{text-align:center;font-size:1.125rem;padding:var(--space-8);background:linear-gradient(135deg,#e67e221a,#fff9);border:3px dashed var(--public-square-accent);position:relative}.public-square-content:before{content:"📢";position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:2rem;background:var(--card-bg);padding:0 var(--space-2)}.announcement-text{font-weight:600;line-height:1.8;margin-bottom:var(--space-4)}.announcement-text strong{font-weight:700;color:var(--public-square-accent)}.announcement-text em{font-style:italic}.timestamp{font-size:.85rem;color:var(--text-secondary);font-style:italic;margin-top:var(--space-4)}.radio-content{background:linear-gradient(135deg,#9b59b626,#0000004d);color:var(--text-light);font-family:var(--font-secondary);padding:var(--space-6)}.radio-display{position:relative}.now-playing{text-align:center;font-weight:700;font-size:1.1rem;color:var(--radio-accent);margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:2px solid var(--radio-accent);letter-spacing:2px}.radio-text{line-height:1.8}.radio-text strong{font-weight:700;color:var(--radio-accent)}.radio-text em{font-style:italic}.newsletter-content{background:#fffffff2;padding:0;overflow:hidden;display:flex;flex-direction:column}.newsletter-header{background:linear-gradient(135deg,var(--newsletter-accent),rgba(52,152,219,.8));color:var(--text-light);padding:var(--space-6);text-align:center;border-bottom:4px double var(--newsletter-accent)}.masthead{font-size:1.5rem;font-weight:700;letter-spacing:3px;margin-bottom:var(--space-2);font-family:var(--font-secondary)}.issue-info{font-size:.9rem;opacity:.9}.newsletter-body{padding:var(--space-6);line-height:1.8;text-align:left;color:var(--text-primary);overflow-y:auto;flex:1;min-height:0}.newsletter-body p{margin-bottom:var(--space-4)}.newsletter-body p:first-of-type:first-letter{font-size:3rem;font-weight:700;float:left;line-height:1;margin-right:var(--space-2);color:var(--newsletter-accent)}.newsletter-body strong{font-weight:700;color:var(--newsletter-accent)}.newsletter-body em{font-style:italic;color:var(--text-secondary)}button{position:relative;overflow:hidden}button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}button:active:not(:disabled):before{width:300px;height:300px}button.error-button{border-color:var(--error);color:var(--error)}button.error-button:hover:not(:disabled){background:#e74c3c1a}@media (max-width: 768px){button{min-height:44px;padding:var(--space-4) var(--space-6);font-size:1.05rem}.city-card{min-height:200px}.city-grid{grid-template-columns:1fr;gap:var(--space-6)}header h1{font-size:2rem}.city h2{font-size:2rem}.city-features{flex-direction:column}.city-features section{max-width:100%}}@media (min-width: 769px) and (max-width: 1024px){.city-grid{grid-template-columns:repeat(2,1fr)}.city-features section{flex:0 1 280px;max-width:280px}}.home-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-8);flex-wrap:wrap;gap:var(--space-4)}.home-header h2{margin:0}.create-city-btn{background:linear-gradient(135deg,var(--public-square-accent),var(--newsletter-accent));color:var(--text-light);border:none;padding:var(--space-3) var(--space-6);font-size:1rem;font-weight:700;box-shadow:0 4px 12px #e67e224d;width:auto;margin:0}.create-city-btn:hover:not(:disabled){background:linear-gradient(135deg,#d35400,#2980b9);box-shadow:0 6px 16px #e67e2266}.create-city-form{background:linear-gradient(135deg,#e67e221a,#3498db1a);padding:var(--space-8);border-radius:12px;margin-bottom:var(--space-8);border:3px solid var(--public-square-accent);box-shadow:0 4px 12px #0000001a;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.create-city-form h3{text-align:center;color:var(--text-primary);margin-bottom:var(--space-6);font-size:1.8rem}.create-city-form form{max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-4)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-weight:600;color:var(--text-primary);font-size:1rem}.form-group input{padding:var(--space-3);border:2px solid var(--text-secondary);border-radius:8px;font-size:1rem;font-family:var(--font-primary);background:#ffffffe6;color:var(--text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.form-group input:focus{outline:none;border-color:var(--public-square-accent);box-shadow:0 0 0 3px #e67e2233}.form-group input::placeholder{color:var(--text-secondary);opacity:.7}.submit-btn{background:linear-gradient(135deg,var(--success),#27ae60);color:var(--text-light);border:none;padding:var(--space-4) var(--space-6);font-size:1.1rem;font-weight:700;margin-top:var(--space-4);box-shadow:0 4px 12px #27ae604d}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#229954,#1e8449);box-shadow:0 6px 16px #27ae6066}.submit-btn:disabled{background:var(--text-secondary);opacity:.6}@media (max-width: 768px){.home-header{flex-direction:column;align-items:stretch}.create-city-btn{width:100%}.create-city-form{padding:var(--space-6)}}.city-pages{margin-top:var(--space-12);padding-top:var(--space-8);border-top:2px solid rgba(112,92,83,.2)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.section-header h3{font-size:1.8rem;color:var(--text-primary);margin:0}.create-page-btn{background:linear-gradient(135deg,var(--success),#27ae60);color:var(--text-light);padding:var(--space-3) var(--space-6);border-radius:8px;text-decoration:none;font-weight:600;transition:all var(--transition-base);display:inline-block}.create-page-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #27ae604d}.page-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-6)}.page-card{background:var(--card-bg);padding:var(--space-6);border-radius:12px;text-decoration:none;color:var(--text-primary);transition:all var(--transition-base);border:2px solid rgba(112,92,83,.2);display:flex;flex-direction:column;gap:var(--space-3)}.page-card:hover{transform:translateY(-3px);box-shadow:0 8px 16px #00000026;border-color:var(--public-square-accent)}.page-type-badge{display:inline-block;padding:var(--space-1) var(--space-3);background:var(--public-square-accent);color:var(--text-light);border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;align-self:flex-start}.page-card h4{font-size:1.3rem;margin:0;color:var(--text-primary)}.page-excerpt{color:var(--text-secondary);font-size:.9rem;line-height:1.5;flex-grow:1}.page-meta{font-size:.85rem;color:var(--text-secondary);margin-top:auto}.page-detail-container{max-width:900px;margin:0 auto;padding:var(--space-8)}.page-detail{background:var(--card-bg);padding:var(--space-8);border-radius:15px}.page-header{margin-bottom:var(--space-8);padding-bottom:var(--space-6);border-bottom:2px solid rgba(112,92,83,.2)}.page-header h1{font-size:2.5rem;margin:var(--space-4) 0;color:var(--text-primary)}.page-content{background:#fff9;padding:var(--space-8);border-radius:12px;line-height:1.8;font-size:1.1rem;white-space:pre-wrap;color:var(--text-primary)}.page-actions{margin-top:var(--space-6);display:flex;gap:var(--space-4);padding-top:var(--space-6);border-top:2px solid rgba(112,92,83,.2)}.delete-btn{background:var(--error);color:var(--text-light);border:none}.delete-btn:hover:not(:disabled){background:#c0392b}.create-page-container{max-width:800px;margin:0 auto;padding:var(--space-8)}.create-page h2{text-align:center;color:var(--text-primary);margin-bottom:var(--space-8);font-size:2.5rem}.page-form{background:var(--card-bg);padding:var(--space-8);border-radius:12px;box-shadow:0 4px 12px #0000001a}.page-form select{width:100%;padding:var(--space-3);border:2px solid var(--text-secondary);border-radius:8px;font-size:1rem;font-family:var(--font-primary);background:#ffffffe6;color:var(--text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base);cursor:pointer}.page-form select:focus{outline:none;border-color:var(--public-square-accent);box-shadow:0 0 0 3px #e67e2233}.page-form textarea{width:100%;padding:var(--space-3);border:2px solid var(--text-secondary);border-radius:8px;font-family:var(--font-primary);font-size:1rem;resize:vertical;background:#ffffffe6;color:var(--text-primary);transition:border-color var(--transition-base),box-shadow var(--transition-base)}.page-form textarea:focus{outline:none;border-color:var(--public-square-accent);box-shadow:0 0 0 3px #e67e2233}.page-form textarea::placeholder{color:var(--text-secondary);opacity:.7}@media (max-width: 768px){.page-list{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:stretch}.create-page-btn{width:100%;text-align:center}.page-detail-container,.create-page-container{padding:var(--space-4)}.page-detail,.page-form{padding:var(--space-6)}.page-header h1{font-size:2rem}.page-content{font-size:1rem;padding:var(--space-6)}}.search-section{margin:var(--space-8) 0;display:flex;flex-direction:column;gap:var(--space-4)}.search-bar{position:relative}.search-input-wrapper{position:relative;display:flex;align-items:center;background:var(--card-bg);border:2px solid var(--text-secondary);border-radius:12px;padding:var(--space-3) var(--space-4);transition:all var(--transition-base)}.search-input-wrapper:focus-within{border-color:var(--public-square-accent);box-shadow:0 0 0 3px #e67e2233}.search-icon{font-size:1.2rem;margin-right:var(--space-3);color:var(--text-secondary)}.search-input{flex:1;border:none;background:transparent;font-size:1rem;font-family:var(--font-primary);color:var(--text-primary);outline:none}.search-input::placeholder{color:var(--text-secondary);opacity:.7}.clear-button{background:transparent;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;padding:var(--space-2);margin:0;width:auto;min-height:auto;transition:color var(--transition-base);display:flex;align-items:center;justify-content:center}.clear-button:hover{color:var(--text-primary);transform:none;box-shadow:none;background:transparent}.search-loading{position:absolute;top:100%;left:0;margin-top:var(--space-2);font-size:.85rem;color:var(--text-secondary);font-style:italic}.filter-bar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}.filter-controls{display:flex;gap:var(--space-3);flex-wrap:wrap;align-items:center}.theme-filter,.sort-filter{padding:var(--space-2) var(--space-4);border:2px solid var(--text-secondary);border-radius:8px;background:var(--card-bg);color:var(--text-primary);font-family:var(--font-primary);font-size:.95rem;cursor:pointer;transition:all var(--transition-base);min-height:44px}.theme-filter:hover,.sort-filter:hover{border-color:var(--text-primary)}.theme-filter:focus,.sort-filter:focus{outline:none;border-color:var(--public-square-accent);box-shadow:0 0 0 3px #e67e2233}.clear-filters-btn{background:#e74c3c1a;border:2px solid var(--error);color:var(--error);padding:var(--space-2) var(--space-4);font-size:.9rem;font-weight:600;width:auto;margin:0;min-height:44px}.clear-filters-btn:hover:not(:disabled){background:#e74c3c33;transform:translateY(-2px)}.result-count{font-size:.95rem;color:var(--text-secondary);font-weight:600}mark{background:#e67e224d;color:var(--text-primary);padding:0 2px;border-radius:2px;font-weight:600}@media (max-width: 768px){.search-section{margin:var(--space-6) 0}.filter-bar{flex-direction:column;align-items:stretch}.filter-controls{width:100%;flex-direction:column}.theme-filter,.sort-filter,.clear-filters-btn{width:100%}.result-count{text-align:center;padding:var(--space-2) 0}}.content-mode-selector{margin-bottom:var(--space-8);padding:var(--space-6);background:#ffffff80;border-radius:12px}.content-mode-selector h3{text-align:center;margin-bottom:var(--space-6);color:var(--text-primary);font-size:1.3rem}.mode-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-4)}.mode-option{display:flex;flex-direction:column;align-items:center;padding:var(--space-6);background:#fffc;border:3px solid rgba(112,92,83,.3);border-radius:12px;cursor:pointer;transition:all var(--transition-base);text-align:center;width:100%}.mode-option:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 6px 12px #00000026;border-color:var(--public-square-accent)}.mode-option.active{background:linear-gradient(135deg,#e67e2233,#3498db33);border-color:var(--public-square-accent);border-width:4px;box-shadow:0 4px 12px #e67e224d}.mode-option:disabled{opacity:.6;cursor:not-allowed}.mode-icon{font-size:3rem;margin-bottom:var(--space-3);display:block}.mode-title{font-size:1.3rem;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2);display:block}.mode-desc{font-size:.9rem;color:var(--text-secondary);display:block}.page-badges{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-3)}.content-tag-badge{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;cursor:help}.tag-ai{background:#3498db;color:#fff}.tag-user{background:#27ae60;color:#fff}.tag-detected{background:#e67e22;color:#fff}.tag-pending{background:#95a5a6;color:#fff;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.field-hint{font-size:.85rem;color:var(--text-secondary);margin-top:var(--space-2);font-style:italic;line-height:1.4}.page-detail .page-badges{margin-bottom:var(--space-4)}.page-detail .content-tag-badge{font-size:.8rem;padding:var(--space-2) var(--space-4)}@media (max-width: 768px){.mode-options{grid-template-columns:1fr}.mode-icon{font-size:2.5rem}.mode-title{font-size:1.1rem}.mode-desc{font-size:.85rem}}:root{--bg-gradient-start: #705C53;--bg-gradient-end: #FFF2E1;--text-primary: #3D2E29;--text-secondary: #6B5B54;--text-light: #FFFFFF;--public-square-accent: #E67E22;--radio-accent: #9B59B6;--newsletter-accent: #3498DB;--success: #27AE60;--error: #E74C3C;--warning: #F39C12;--info: #3498DB;--card-bg: rgba(255, 255, 255, .9);--card-bg-hover: rgba(255, 255, 255, .95);--overlay-dark: rgba(61, 46, 41, .7);--button-bg: rgba(112, 92, 83, .2);--button-bg-hover: rgba(112, 92, 83, .3);--font-primary: "Comic Sans MS", "Chalkboard SE", "Arial", sans-serif;--font-secondary: "Courier New", monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-primary);background:#fff2e1;color:var(--text-primary);min-height:100vh}#root{min-height:100vh}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
