.newsletter-home-page{min-height:100vh;background:#fff}.newsletter-hero{padding:10rem 2rem 6rem;text-align:center;display:flex;justify-content:center;align-items:center}.newsletter-hero .hero-container{max-width:900px;margin:0 auto;width:100%}.newsletter-hero .hero-content{max-width:100%;display:flex;flex-direction:column;align-items:center}.newsletter-hero h1{font-size:2.5rem;font-weight:700;color:#2d3748;margin-bottom:1.5rem;line-height:1.2;text-align:center}.newsletter-hero h1 .underline-text{color:#9a32b0;text-decoration:underline;text-decoration-color:#9a32b0;text-decoration-thickness:3px;text-underline-offset:4px}.newsletter-hero .hero-subtitle{font-size:1.25rem;color:#4a5568;margin-bottom:2.5rem;line-height:1.6;text-align:center}.newsletter-hero .hero-note{font-size:.9rem;color:#718096;margin-top:1.5rem;text-align:center}.newsletter-cta{max-width:100%;width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:center}.newsletter-hero .newsletter-cta{max-width:650px}.newsletter-form{display:flex;gap:.75rem;margin-bottom:.75rem;width:100%}.newsletter-input{flex:1;padding:1rem 1.25rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;transition:border-color .2s}.newsletter-input:focus{outline:none;border-color:#9a32b0}.newsletter-input:disabled{background:#f3f4f6;cursor:not-allowed}.newsletter-button{padding:1rem 2rem;background:#32b09a;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;cursor:pointer;transition:background .2s;white-space:nowrap}.newsletter-button:hover:not(:disabled){background:#247d0f}.newsletter-button:disabled{background:#cbd5e1;cursor:not-allowed}.newsletter-privacy{margin:0;font-size:.875rem;color:#6b7280;text-align:center}.newsletter-privacy a{color:#6b7280;text-decoration:underline}.error-message{color:#dc2626;font-size:.875rem;margin-top:.5rem;text-align:center}.success-message{background:#d1fae5;border:1px solid #6ee7b7;border-radius:8px;padding:1.5rem;text-align:center}.success-message p{margin:0;color:#065f46;font-weight:500}.what-you-get{padding:5rem 2rem;background:linear-gradient(135deg,#f8f4f9,#fff)}.what-you-get h2{text-align:center;font-size:2rem;color:#2d3748;margin-bottom:3rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2.5rem;max-width:1200px;margin:0 auto}.feature{text-align:center}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature h3{font-size:1.25rem;color:#2d3748;margin-bottom:.75rem}.feature p{color:#4a5568;line-height:1.6}.cta-section-alt{padding:5rem 2rem;background:#fff;text-align:center;display:flex;flex-direction:column;align-items:center}.cta-section-alt h2{font-size:2rem;color:#2d3748;margin-bottom:1rem}.cta-section-alt .section-subtitle{font-size:1.125rem;color:#4a5568;margin-bottom:2.5rem}.cta-section-alt .container{width:100%;display:flex;flex-direction:column;align-items:center}.cta-section-alt .newsletter-cta{width:100%;max-width:650px}.recent-topics{padding:5rem 2rem;background:#fff}.recent-topics h2{text-align:center;font-size:2rem;color:#2d3748;margin-bottom:3rem}.topics-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.topic-link{text-decoration:none;color:inherit;display:block;transition:transform .2s}.topic-link:hover{transform:translate(8px)}.topic{padding:2rem;background:#f9f2f9;border-radius:12px;border-left:4px solid #9a32b0;transition:all .2s}.topic-link:hover .topic{background:#f4e8f7;border-left-color:#7a1e8a}.topic h3{font-size:1.25rem;color:#5a1e6b;margin-bottom:.75rem}.topic p{color:#4a5568;line-height:1.6;margin:0}@media (max-width: 768px){.newsletter-hero{padding:6rem 1.5rem 4rem}.newsletter-hero h1{font-size:1.75rem}.newsletter-hero .hero-subtitle{font-size:1rem}.newsletter-form{flex-direction:column}.newsletter-button{width:100%}.features-grid{grid-template-columns:1fr;gap:2rem}.what-you-get,.cta-section-alt,.recent-topics{padding:3rem 1.5rem}.cta-section-alt h2,.recent-topics h2,.what-you-get h2{font-size:1.5rem}}.site-header{background-color:#fff;box-shadow:0 2px 4px #0000001a;position:fixed;top:0;left:0;right:0;z-index:100;transition:transform .3s ease-in-out}.site-header.header-visible{transform:translateY(0)}.site-header.header-hidden{transform:translateY(-100%)}.site-header nav{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;max-width:1200px;margin:0 auto}.site-header .logo{height:65px;display:flex;align-items:center}.site-header .logo img{height:100%;width:auto}.site-header nav ul{list-style:none;display:flex;gap:2rem;margin:0;padding:0}.site-header nav a{text-decoration:none;color:#666;transition:color .3s}.site-header nav a:hover{color:#1a365d}.site-header nav .nav-cta{background:#9a32b0;color:#fff;padding:.5rem 1.25rem;border-radius:5px;font-weight:600;transition:all .3s}.site-header nav .nav-cta:hover{background:#7a2890;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #9a32b040}.site-header nav .nav-signin{color:#9a32b0;font-weight:600;padding:.5rem 1.25rem;border:2px solid #9a32b0;border-radius:5px;transition:all .3s}.site-header nav .nav-signin:hover{background:#9a32b0;color:#fff;transform:translateY(-1px)}.site-header .mobile-menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;flex-direction:column;gap:4px;z-index:1001}.site-header .burger-line{display:block;width:25px;height:3px;background:#666;border-radius:2px;transition:all .3s}.site-header .mobile-menu-toggle.menu-open .burger-line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.site-header .mobile-menu-toggle.menu-open .burger-line:nth-child(2){opacity:0}.site-header .mobile-menu-toggle.menu-open .burger-line:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.site-header .mobile-menu-overlay{display:none}@media (max-width: 768px){.site-header nav ul{display:none}.site-header .mobile-menu-toggle{display:flex}.site-header .mobile-menu-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:999}.site-header nav ul.mobile-menu-open{display:flex;flex-direction:column;position:fixed;top:0;right:0;bottom:0;width:70%;max-width:300px;background:#fff;padding:5rem 2rem 2rem;gap:1.5rem;z-index:1000;box-shadow:-2px 0 8px #0000001a}.site-header nav ul.mobile-menu-open li{width:100%}.site-header nav ul.mobile-menu-open a{display:block;padding:.75rem 0;font-size:1.125rem}}.site-footer{background:#1a365d;color:#fff;padding:3rem 2rem 2rem;text-align:center}.site-footer .container{max-width:1200px;margin:0 auto;padding:0 2rem}.site-footer .cta-section h2{color:#fff}.site-footer .cta-subtitle{color:#ffffffe6}.site-footer .hero-note{color:#fffc}.site-footer .footer-bottom{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.2)}.site-footer .footer-bottom p{margin:0;color:#fffc}.site-footer .footer-links{margin-top:1rem;display:flex;gap:1rem;justify-content:center;align-items:center}.site-footer .footer-links a{color:#fffc;text-decoration:none;transition:color .2s}.site-footer .footer-links a:hover{color:#fff}.site-footer .footer-links span{color:#ffffff80}.site-footer .footer-newsletter-section{text-align:center;margin-bottom:3rem}.site-footer .footer-newsletter-section h2{font-size:1.75rem;color:#fff;margin-bottom:.75rem}.site-footer .newsletter-subtitle{font-size:1.125rem;color:#ffffffe6;margin-bottom:2rem}.site-footer .newsletter-form{display:flex;gap:.75rem;max-width:500px;margin:0 auto .75rem}.site-footer .newsletter-input{flex:1;padding:1rem 1.25rem;border:2px solid rgba(255,255,255,.3);border-radius:8px;font-size:1rem;background:#ffffff1a;color:#fff;transition:all .2s}.site-footer .newsletter-input::placeholder{color:#fff9}.site-footer .newsletter-input:focus{outline:none;border-color:#fffc;background:#ffffff26}.site-footer .newsletter-input:disabled{background:#ffffff0d;cursor:not-allowed}.site-footer .newsletter-button{padding:1rem 2rem;background:#32b09a;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.site-footer .newsletter-button:hover:not(:disabled){background:#247d0f}.site-footer .newsletter-button:disabled{background:#ffffff4d;cursor:not-allowed}.site-footer .newsletter-error{color:#ff6b6b;font-size:.875rem;margin-top:.5rem;text-align:center}.site-footer .newsletter-success{background:#32b09a33;border:1px solid rgba(50,176,154,.5);border-radius:8px;padding:1.5rem;text-align:center;max-width:500px;margin:0 auto}.site-footer .newsletter-success p{margin:0;color:#d1fae5;font-weight:500}.site-footer .newsletter-note{font-size:.9rem;color:#ffffffb3;margin-top:1.5rem}.site-footer .newsletter-privacy{margin:.75rem 0 0;font-size:.875rem;color:#fff9;text-align:center}.site-footer .newsletter-privacy a{color:#fffc;text-decoration:underline}.site-footer .newsletter-privacy a:hover{color:#fff}.container{max-width:1200px;margin:0 auto;padding:0 2rem}@media (max-width: 640px){.site-footer .newsletter-form{flex-direction:column}.site-footer .newsletter-button{width:100%}}.school-selector{position:relative;width:100%}.search-wrapper{position:relative}.search-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .2s}.search-input:focus{outline:none;border-color:#902ba4}.loading-indicator{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:#666}.selected-school{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background-color:#f0f0f0;border:1px solid #ddd;border-radius:6px}.selected-school span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.clear-button{background:none;border:none;color:#666;font-size:1.4rem;line-height:1;padding:0 .25rem;cursor:pointer;margin-left:.5rem}.clear-button:hover{color:#dc3545}.dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:6px;box-shadow:0 4px 12px #00000026;max-height:300px;overflow-y:auto;z-index:100;list-style:none;padding:0}.dropdown-item{padding:.75rem 1rem;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;border-bottom:1px solid #f0f0f0}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:#f5f5f5}.school-name{font-weight:500;color:#333}.school-location{font-size:.85rem;color:#666}.dropdown.no-results,.dropdown.hint{padding:1rem;color:#666;text-align:center;font-style:italic}.preferences-page{min-height:100vh;background-color:#f5f5f5;padding:2rem 1rem}.preferences-card{max-width:900px;margin:0 auto;background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;overflow:hidden}.preferences-header{padding:2rem;border-bottom:1px solid #eee;text-align:left}.preferences-header .logo{height:50px;margin-bottom:1.5rem}.preferences-header h1{color:#2c3e50;font-size:2rem;font-weight:600;margin-bottom:.75rem}.preferences-header p{color:#666;font-size:1.1rem;line-height:1.6;max-width:600px}.preferences-content{padding:2rem}.save-status{padding:.75rem 2rem;text-align:center;font-size:.9rem;font-weight:500}.save-status.saving{background-color:#fff3cd;color:#856404}.save-status.saved{background-color:#d4edda;color:#155724}.save-status.error{background-color:#f8d7da;color:#721c24}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.form-group input[type=text],.form-group input[type=email],.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#902ba4}.category-section{margin-bottom:2.5rem;padding:2rem;background-color:#fafafa;border-radius:12px;border:1px solid #e0e0e0}.category-section h2{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:.75rem}.section-subtitle{color:#666;margin-bottom:1.5rem}.category-options{display:flex;flex-direction:column;gap:1rem}.category-option{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;padding:1rem;background:#fff;border-radius:8px;border:1px solid #e0e0e0;transition:border-color .2s,background-color .2s}.category-option:hover{border-color:#902ba4;background-color:#faf5fb}.category-option input[type=checkbox]{margin-top:.25rem;width:18px;height:18px;accent-color:#902ba4}.category-option .option-content{display:flex;flex-direction:column;gap:.25rem}.category-option .option-content strong{color:#333}.category-option .option-content span{color:#666;font-size:.9rem}.detail-section{margin-bottom:2rem;padding:2rem;border-radius:12px}.detail-section h3{font-size:1.3rem;font-weight:600;margin-bottom:1rem}.parent-section{background-color:#f8fbff;border:1px solid #e3f2fd}.parent-section h3{color:#1976d2}.educator-section{background-color:#fff8f5;border:1px solid #ffe0cc}.educator-section h3{color:#e65100}.place-based-section{background-color:#f3f9f3;border:1px solid #c8e6c9}.place-based-section h3{color:#2e7d32}.add-button{padding:.5rem 1rem;background-color:#007bff;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:background-color .2s}.add-button:hover{background-color:#0056b3}.remove-button{padding:.25rem .75rem;background-color:#dc3545;color:#fff;border:none;border-radius:4px;font-size:.8rem;transition:background-color .2s}.remove-button:hover{background-color:#c82333}.child-card{margin-top:1.5rem;padding:1.5rem;background:#fff;border-radius:8px;border:1px solid #e0e0e0}.child-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.child-header h4{margin:0;color:#333}.child-type-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.child-type-options label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.child-type-options input[type=radio]{accent-color:#1976d2}.child-fields{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 600px){.child-fields{grid-template-columns:1fr}}.area-type-options{display:flex;flex-direction:column;gap:.75rem}.area-type-options label{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer}.area-type-options input[type=radio]{margin-top:.25rem;accent-color:#2e7d32}.area-type-options span{color:#333}.area-type-options span strong{color:#2e7d32}.selected-items{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.selected-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background-color:#f0f0f0;border-radius:20px;font-size:.9rem}.selected-item button{background:none;border:none;color:#666;font-size:1.2rem;line-height:1;padding:0;cursor:pointer}.selected-item button:hover{color:#dc3545}.empty-state{color:#666;font-style:italic;margin-top:1rem}.preferences-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.loading{color:#666;font-size:1.1rem}.error-message{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb;padding:1.5rem 2rem;border-radius:8px;max-width:500px;text-align:center}.newsletter-view-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background-color:#f5f5f5}.loading-state{text-align:center}.loading-icon{font-size:4rem;margin-bottom:1rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}.loading-state p{color:#666;font-size:1.1rem}.error-state{text-align:center;max-width:400px;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a}.error-state h2{color:#dc3545;margin-bottom:1rem}.error-state p{color:#666;margin-bottom:1.5rem}.back-link{display:inline-block;padding:.75rem 1.5rem;background-color:#902ba4;color:#fff;text-decoration:none;border-radius:6px;transition:background-color .2s}.back-link:hover{background-color:#7a2490}.newsletter-view{max-width:600px;margin:0 auto;background-color:#fff;min-height:100vh}.newsletter-header{padding:2rem;text-align:center;border-bottom:1px solid #eee}.newsletter-header .logo{height:50px}.newsletter-title-section{padding:2rem;text-align:left;border-bottom:1px solid #eee}.newsletter-title-section h1{color:#2c3e50;font-size:1.75rem;font-weight:600;margin-bottom:.75rem}.newsletter-title-section .greeting{color:#333;font-size:1.1rem;margin-bottom:.5rem}.newsletter-title-section .date{color:#666;font-size:.9rem}.newsletter-content{padding:2rem}.metrics-section h2{color:#2c3e50;font-size:1.3rem;margin-bottom:1.5rem}.school-metrics{margin-bottom:2rem;padding:1.5rem;background-color:#f8f9fa;border-radius:8px}.school-metrics h3{color:#333;font-size:1.1rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #902ba4}.metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.metric-card{display:flex;flex-direction:column;padding:1rem;background:#fff;border-radius:6px;border:1px solid #e0e0e0}.metric-label{font-size:.85rem;color:#666;text-transform:capitalize;margin-bottom:.25rem}.metric-value{font-size:1.5rem;font-weight:600;color:#2c3e50}.content-sections .content-section{margin-bottom:2rem}.content-sections h2{color:#2c3e50;font-size:1.2rem;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #902ba4}.content-sections p{color:#333;line-height:1.7}.schools-section h2{color:#2c3e50;font-size:1.2rem;margin-bottom:1rem}.schools-list{list-style:none;padding:0}.schools-list li{padding:.75rem 1rem;background-color:#f8f9fa;border-radius:6px;margin-bottom:.5rem}.generic-content{color:#333;line-height:1.7}.personalisation-summary{margin-top:1.5rem;padding:1rem;background-color:#f8f9fa;border-radius:8px}.personalisation-summary h3{font-size:1rem;margin-bottom:.75rem}.personalisation-summary pre{font-size:.8rem;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}.newsletter-cta{padding:2rem;margin:1rem 2rem;background:linear-gradient(135deg,#f8f5fb,#f0e6f3);border-radius:12px;text-align:center}.newsletter-cta h3{color:#902ba4;font-size:1.2rem;margin-bottom:.5rem}.newsletter-cta p{color:#666;margin-bottom:1rem}.cta-button{display:inline-block;padding:.75rem 1.5rem;background-color:#902ba4;color:#fff;text-decoration:none;border-radius:6px;font-weight:500;transition:background-color .2s}.cta-button:hover{background-color:#7a2490}.newsletter-footer{padding:2rem;text-align:center;background-color:#f8f9fa;border-top:1px solid #eee}.newsletter-footer p{color:#666;font-size:.9rem;margin-bottom:.75rem}.footer-links{display:flex;justify-content:center;align-items:center;gap:.5rem}.footer-links a{color:#902ba4;text-decoration:none;font-size:.9rem}.footer-links a:hover{text-decoration:underline}.footer-links .divider{color:#ccc}@media (max-width: 600px){.newsletter-view{max-width:100%}.metrics-grid{grid-template-columns:1fr}.newsletter-cta{margin:1rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;line-height:1.6}#root{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}
