:root{--monterotondo-blu: rgb(86, 188, 247);--monterotondo-giallo: rgb(240, 222, 78);--monterotondo-blu-scuro: rgb(66, 168, 227);--monterotondo-blu-chiaro: rgb(106, 208, 255);--monterotondo-giallo-scuro: rgb(220, 202, 58);--monterotondo-giallo-chiaro: rgb(250, 232, 98);--text-primary: #000000;--text-secondary: #333333;--text-light: #666666;--background-white: #ffffff;--background-light: #f8f9fa;--border-color: #e0e0e0;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-xxl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 20px;--radius-round: 50%;--transition-fast: .2s ease;--transition-medium: .3s ease;--transition-slow: .5s ease}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:var(--text-primary);background-color:var(--background-white);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}a{color:#3498db;text-decoration:none;transition:color .3s ease}a:hover{color:#2980b9;text-decoration:underline}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:600}button{font-family:inherit;cursor:pointer;transition:all .3s ease}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#555}::selection{background-color:#3498db;color:#fff}@media print{.no-print{display:none}}.header{background:linear-gradient(135deg,var(--monterotondo-blu) 0%,var(--monterotondo-giallo) 100%);color:var(--text-primary);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:100}.header-container{max-width:1200px;margin:0 auto;padding:1rem;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:1rem}.header-stemma{height:2.5rem;width:auto;object-fit:contain}.header-title{font-size:2rem;margin:0;font-weight:700;letter-spacing:1px;color:var(--text-primary)}.header-nav{display:flex;gap:2rem;align-items:center}.header-nav-link{color:var(--text-primary);text-decoration:none;font-weight:600;font-size:1.1rem;padding:.5rem 1rem;border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative}.header-nav-link:hover{background-color:#0000001a;color:var(--text-primary);text-decoration:none;transform:translateY(-1px)}.header-nav-link.active{background-color:#00000026;color:var(--text-primary)}.header-subtitle-container{background:#0000000d;padding:.75rem 1rem;text-align:center}.header-subtitle{font-size:1rem;margin:0;opacity:.9;font-weight:400;max-width:1200px}.header-container{flex-direction:column;gap:1rem;padding:1rem .5rem}.header-left{gap:.75rem}.header-stemma{height:2rem}.header-title{font-size:2rem}.header-nav{gap:1.5rem}.header-nav-link{font-size:1rem;padding:.4rem .8rem}.header-subtitle{font-size:.9rem}.photo-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease;height:100%;display:flex;flex-direction:column;cursor:pointer}.photo-card:hover{transform:translateY(-5px);box-shadow:0 5px 20px #00000026}.photo-card-image-container{position:relative;width:100%;padding-bottom:75%;overflow:hidden;background-color:#f0f0f0}.photo-card-image{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease}.photo-card-image.loaded{opacity:1}.photo-card-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#999;font-size:.9rem}.photo-card-content{padding:1rem;flex:1;display:flex;flex-direction:column;justify-content:space-between}.photo-card-description{margin:0 0 1rem;color:#333;font-size:1rem;line-height:1.5}.photo-card-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.photo-card-date{color:#666;font-size:.875rem}.photo-card-click-hint{color:var(--monterotondo-blu);font-size:.875rem;font-weight:500}@media (max-width: 480px){.photo-card-content{padding:.75rem}.photo-card-description{font-size:.9rem}}.modal-overlay{position:fixed;inset:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--background-white);border-radius:var(--radius-lg);max-width:90vw;max-height:90vh;width:100%;position:relative;animation:slideIn .3s ease;box-shadow:var(--shadow-lg);overflow:auto;display:flex;flex-direction:column}@keyframes slideIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.modal-close{position:absolute;top:1rem;right:1rem;background:#00000080;color:#fff;border:none;border-radius:50%;width:2.5rem;height:2.5rem;font-size:1.5rem;cursor:pointer;transition:all var(--transition-fast);z-index:10;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#000000b3;transform:scale(1.1)}.modal-body{display:flex;flex-direction:column;align-items:center;padding:3rem 2rem 2rem;text-align:center;gap:1.5rem}.modal-description{flex-shrink:0}.modal-description h2{color:var(--text-primary);margin:0 0 .5rem;font-size:1.5rem;font-weight:600}.modal-date{color:var(--text-secondary);margin:0;font-size:1rem;font-style:italic}.modal-image-container{display:flex;justify-content:center;align-items:center;width:100%;padding:1rem}.modal-image{max-width:calc(90vw - 4rem);max-height:calc(90vh - 200px);width:auto;height:auto;border-radius:var(--radius-md);box-shadow:var(--shadow-md);object-fit:contain;display:block}.modal-image-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;width:400px;height:300px;background:var(--background-light);border-radius:var(--radius-md);border:2px dashed var(--border-color);color:var(--text-secondary);text-align:center}.modal-image-placeholder p{margin:0 0 .5rem;font-size:1.1rem}.modal-image-placeholder small{opacity:.7}.modal-footer{width:100%;display:flex;justify-content:center;flex-shrink:0;padding-bottom:1rem}.maps-link{display:inline-flex;align-items:center;gap:.5rem;background:var(--monterotondo-blu);color:var(--text-primary);padding:1rem 2rem;border-radius:var(--radius-lg);text-decoration:none;font-weight:600;font-size:1.1rem;transition:all var(--transition-medium);box-shadow:var(--shadow-sm)}.maps-link:hover{background:var(--monterotondo-blu-scuro);text-decoration:none;color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.modal-overlay{padding:1rem}.modal-content{max-width:100%;max-height:100%;border-radius:var(--radius-md)}.modal-body{padding:2rem 1.5rem 1.5rem;gap:1.5rem}.modal-description h2{font-size:1.3rem}.modal-image{max-width:calc(100vw - 3rem);max-height:calc(100vh - 180px)}.modal-image-placeholder{width:100%;height:250px}.maps-link{padding:.875rem 1.5rem;font-size:1rem;width:100%;justify-content:center}.modal-close{width:2rem;height:2rem;font-size:1.2rem;top:.75rem;right:.75rem}}.photo-gallery{padding:3rem 1rem;background-color:#f8f9fa;min-height:50vh}.gallery-container{max-width:1200px;margin:0 auto}.gallery-search{padding:.75rem 1.5rem;border:1px solid var(--border-color);border-radius:25px;font-size:1rem;width:100%;max-width:300px;transition:border-color var(--transition-fast)}.gallery-search:focus{outline:none;border-color:var(--monterotondo-blu)}.gallery-contact{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;background:var(--background-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-top:1.5rem;margin-bottom:2rem;text-align:center}.contact-text{color:var(--text-secondary);font-size:.9rem;font-weight:500}.contact-email{color:var(--monterotondo-blu-scuro);text-decoration:none;font-weight:600;padding:.5rem 1rem;background:var(--monterotondo-giallo-chiaro);border-radius:var(--radius-md);transition:all var(--transition-fast);font-size:.9rem}.contact-email:hover{background:var(--monterotondo-giallo-scuro);text-decoration:none;color:var(--text-primary);transform:translateY(-1px)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.gallery-empty{text-align:center;color:#666;font-size:1.1rem;margin-top:3rem}@media (max-width: 768px){.photo-gallery{padding:2rem 1rem}.gallery-controls{flex-direction:column;align-items:stretch;gap:1rem}.gallery-search{max-width:100%}.gallery-contact{flex-direction:column;gap:.5rem;padding:1rem;margin-top:1rem}.contact-text{font-size:.8rem}.contact-email{font-size:.8rem;padding:.4rem .8rem}.gallery-grid{grid-template-columns:1fr;gap:1.5rem}}@media (max-width: 480px){.gallery-grid{gap:1rem}}.proposte-section{padding:3rem 1rem;background-color:var(--background-light);min-height:50vh}.proposte-container{max-width:1200px;margin:0 auto}.proposte-items{display:grid;gap:1.5rem}.proposta-item{background:var(--background-white);padding:1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-medium)}.proposta-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.item-content{width:100%}.item-titolo{color:var(--text-primary);margin:0 0 .5rem;font-size:1.3rem;font-weight:600}.item-descrizione{color:var(--text-secondary);margin:0 0 1rem;line-height:1.6;font-size:1rem}.item-data{color:var(--text-light);font-size:.9rem;margin:0;font-style:italic}.proposte-empty{text-align:center;color:var(--text-secondary);font-size:1.1rem;margin-top:3rem;padding:2rem;background:var(--background-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}@media (max-width: 768px){.proposte-section{padding:2rem 1rem}.proposta-item{padding:1rem}.item-titolo{font-size:1.1rem}.item-descrizione{font-size:.9rem}}.footer{background:var(--monterotondo-blu);padding:2rem 1rem 3rem;text-align:center;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto}.footer-text{color:#000;margin:.75rem auto;font-size:.85rem;line-height:1.5;max-width:800px}.footer-text strong{color:var(--monterotondo-giallo);font-weight:700;text-transform:uppercase}.app{min-height:100vh;display:flex;flex-direction:column;background-color:#fff}.main-content{flex:1;width:100%}html{scroll-behavior:smooth}*{box-sizing:border-box}img{max-width:100%;height:auto}button:focus,input:focus,textarea:focus{outline:2px solid #3498db;outline-offset:2px}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#666}.error{color:#e74c3c;text-align:center;padding:2rem}.text-center{text-align:center}.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}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.section-title{font-size:2rem;color:var(--text-primary);margin:0;font-weight:600}@media (max-width: 768px){.hide-mobile{display:none}.section-header{flex-direction:column;align-items:stretch}.section-title{font-size:1.5rem;text-align:center}}@media (min-width: 769px){.hide-desktop{display:none}}
