:root{--blue-dark: #1B3A7A;--blue-light: #4A8FD4;--gold: #F5C100;--gold-dim: #e6b000;--white: #FFFFFF;--off-white: #F8F7F4;--gray-light: #ECEAE4;--gray-mid: #9B9590;--text: #1A1917;--red: #e74c3c;--green: #27ae60;--radius: 12px;--radius-lg: 20px;--shadow-sm: 0 2px 12px rgba(27,58,122,.07);--shadow-md: 0 8px 40px rgba(27,58,122,.13)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:Jost,sans-serif;background:var(--off-white);color:var(--text);-webkit-font-smoothing:antialiased}.site-header{background:var(--blue-dark);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:0 2px 20px #0003}.site-header-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}.site-header-logo img{height:36px;width:36px;object-fit:contain}.site-header-logo-text{color:#fff;font-weight:700;font-size:.85rem;line-height:1.2}.site-header-logo-text span{display:block;font-size:.65rem;font-weight:400;opacity:.6}.sign-btn-header{background:var(--gold);color:var(--blue-dark);border:none;border-radius:50px;padding:.55rem 1.4rem;font-family:Jost,sans-serif;font-size:.85rem;font-weight:700;cursor:pointer;text-decoration:none;transition:background .2s;white-space:nowrap}.sign-btn-header:hover{background:var(--gold-dim)}.hero{background:linear-gradient(150deg,var(--blue-dark) 0%,#0f2557 100%);color:#fff;padding:5rem 2rem 4rem;text-align:center}.hero-badge{display:inline-block;background:#f5c10026;border:1px solid rgba(245,193,0,.4);color:var(--gold);font-size:.7rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;padding:.35rem 1rem;border-radius:50px;margin-bottom:1.5rem}.hero h1{font-family:Cormorant Garamond,serif;font-size:clamp(2rem,5vw,3.5rem);font-weight:700;line-height:1.1;margin-bottom:.75rem}.hero-sub{font-size:clamp(1rem,2vw,1.25rem);font-style:italic;color:#ffffffb3;margin-bottom:.5rem}.hero-district{font-size:.88rem;color:#ffffff80;margin-bottom:2.5rem;letter-spacing:.05em}.sig-counter{display:inline-flex;align-items:center;gap:1.5rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-lg);padding:1.25rem 2.5rem;margin-bottom:2.5rem}.sig-count-num{font-family:Cormorant Garamond,serif;font-size:2.5rem;font-weight:700;color:var(--gold);line-height:1}.sig-count-label{font-size:.78rem;color:#fff9;text-transform:uppercase;letter-spacing:.1em}.hero-cta{display:inline-flex;align-items:center;gap:.5rem;background:var(--gold);color:var(--blue-dark);border:none;border-radius:50px;padding:.9rem 2.5rem;font-family:Jost,sans-serif;font-size:1rem;font-weight:700;cursor:pointer;text-decoration:none;transition:all .2s}.hero-cta:hover{background:var(--gold-dim);transform:translateY(-1px)}.page-wrap{max-width:860px;margin:0 auto;padding:3rem 2rem 5rem}.letter-wrap{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:3rem}.letter-header{background:var(--blue-dark);padding:2.5rem 3rem;text-align:center;color:#fff}.letter-header img{height:60px;width:60px;object-fit:contain;margin-bottom:1.25rem}.letter-title{font-family:Cormorant Garamond,serif;font-size:1.5rem;font-weight:700;letter-spacing:.05em;margin-bottom:.35rem}.letter-subtitle{font-size:.88rem;font-style:italic;color:#ffffffb3;margin-bottom:.35rem}.letter-district{font-size:.78rem;color:#ffffff80}.letter-body{padding:3rem}.letter-addressee{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--gray-light)}.letter-date{font-size:.85rem;color:var(--gray-mid);margin-bottom:1rem}.letter-to{font-size:.88rem;font-weight:700;color:var(--blue-dark);margin-bottom:.5rem}.letter-recipients{font-size:.85rem;color:var(--text);line-height:1.8}.letter-salutation{font-size:.95rem;margin-bottom:1.5rem;line-height:1.6}.letter-intro{font-size:.95rem;line-height:1.8;color:var(--text);margin-bottom:2rem}.letter-section{margin-bottom:2rem}.letter-section-heading{font-family:Cormorant Garamond,serif;font-size:1.1rem;font-weight:700;color:var(--blue-dark);letter-spacing:.04em;margin-bottom:.85rem;padding-bottom:.4rem;border-bottom:2px solid var(--gold);display:inline-block}.letter-p{font-size:.93rem;line-height:1.8;color:var(--text);margin-bottom:1rem}.letter-p:last-child{margin-bottom:0}.letter-ul{margin:.75rem 0 1rem 1.5rem;font-size:.9rem;line-height:1.8}.letter-ul li{margin-bottom:.35rem}.letter-ul li strong{color:var(--blue-dark)}.letter-closing{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--gray-light);font-size:.9rem;line-height:1.8}.letter-footnote{margin-top:1.5rem;font-size:.78rem;font-style:italic;color:var(--gray-mid)}.sig-section{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;margin-bottom:3rem}.sig-section-header{background:linear-gradient(135deg,var(--blue-dark),#2a4f9a);padding:2rem 2.5rem;color:#fff}.sig-section-title{font-family:Cormorant Garamond,serif;font-size:1.75rem;font-weight:700;margin-bottom:.35rem}.sig-section-sub{font-size:.85rem;color:#ffffffa6}.sig-form-wrap{padding:2.5rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group.full{grid-column:1 / -1}.form-label{font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue-dark)}.form-label .opt{font-weight:400;text-transform:none;letter-spacing:0;color:var(--gray-mid)}.form-input,.form-select{padding:.75rem 1rem;border:1.5px solid var(--gray-light);border-radius:var(--radius);font-family:Jost,sans-serif;font-size:16px;color:var(--text);background:var(--off-white);outline:none;transition:border-color .2s;-webkit-appearance:none;appearance:none;width:100%}.form-input:focus,.form-select:focus{border-color:var(--blue-light);background:var(--white)}.form-hint{font-size:.72rem;color:var(--gray-mid);margin-top:.25rem}.submit-wrap{margin-top:1.75rem;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}.submit-btn{background:var(--blue-dark);color:var(--white);border:none;border-radius:50px;padding:.9rem 2.5rem;font-family:Jost,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;min-height:44px}.submit-btn:hover{background:var(--blue-light)}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.form-disclaimer{font-size:.75rem;color:var(--gray-mid);line-height:1.5;max-width:480px}.feedback-box{width:100%;padding:1rem 1.25rem;border-radius:var(--radius);font-size:.88rem;display:none}.feedback-box.success{display:block;background:#27ae6014;border:1px solid rgba(39,174,96,.3);color:#1a7a40}.feedback-box.error{display:block;background:#e74c3c14;border:1px solid rgba(231,76,60,.3);color:var(--red)}.spinner-sm{display:inline-block;width:13px;height:13px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:5px}@keyframes spin{to{transform:rotate(360deg)}}.sigs-section{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.sigs-header{padding:1.75rem 2.5rem;border-bottom:1px solid var(--gray-light);display:flex;align-items:center;justify-content:space-between}.sigs-header-title{font-family:Cormorant Garamond,serif;font-size:1.4rem;font-weight:700;color:var(--blue-dark)}.sigs-header-count{font-size:.78rem;color:var(--gray-mid);background:var(--off-white);padding:.3rem .75rem;border-radius:50px}.sig-row{display:flex;align-items:flex-start;gap:1.25rem;padding:1.1rem 2.5rem;border-bottom:1px solid var(--gray-light);transition:background .12s}.sig-row:last-child{border-bottom:none}.sig-row:hover{background:var(--off-white)}.sig-avatar{width:40px;height:40px;border-radius:50%;background:var(--blue-dark);display:flex;align-items:center;justify-content:center;font-family:Cormorant Garamond,serif;font-size:1rem;font-weight:700;color:var(--gold);flex-shrink:0}.sig-info{flex:1;min-width:0}.sig-name{font-weight:700;font-size:.92rem;color:var(--blue-dark)}.sig-creds{font-size:.82rem;color:var(--blue-light);font-weight:600}.sig-meta{font-size:.75rem;color:var(--gray-mid);margin-top:.15rem}.sigs-loading,.sigs-empty{padding:3rem;text-align:center;color:var(--gray-mid);font-size:.88rem}.page-footer{background:var(--blue-dark);color:#ffffff80;text-align:center;padding:2rem;font-size:.78rem;line-height:1.6}.page-footer a{color:#fff9;text-decoration:none}.page-footer a:hover{color:#fff}@media(max-width:640px){.page-wrap{padding:2rem 1.25rem 4rem}.letter-body,.sig-form-wrap{padding:1.75rem}.form-grid{grid-template-columns:1fr}.form-group.full{grid-column:1}.sig-section-header{padding:1.5rem 1.75rem}.sigs-header{padding:1.25rem 1.75rem}.sig-row{padding:1rem 1.75rem}.letter-header{padding:2rem 1.75rem}.hero{padding:3.5rem 1.5rem 3rem}.sig-counter{flex-direction:column;gap:.5rem;text-align:center;padding:1.25rem 2rem}}
