*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-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:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh}h1,h2,h3,h4,h5,h6{line-height:1.2}a{font-weight:500;text-decoration:inherit}button{font-family:inherit}.navbar{background:#fff;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:1000;padding:1rem 0}.nav-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center}.nav-logo{font-size:1.8rem;font-weight:800;text-decoration:none;color:#333}.logo-highlight{color:#667eea}.nav-menu{display:flex;list-style:none;align-items:center;gap:30px;margin:0;padding:0}.nav-item{margin:0}.nav-link{text-decoration:none;color:#333;font-weight:500;transition:color .3s ease}.nav-link:hover{color:#667eea}.nav-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 24px;border-radius:6px;font-weight:600;cursor:pointer;transition:all .3s ease}.nav-btn:hover{transform:translateY(-2px);box-shadow:0 6px 15px #667eea4d}@media(max-width:768px){.nav-menu{gap:15px;font-size:.9rem}.nav-btn{padding:8px 16px;font-size:.9rem}.nav-logo{font-size:1.5rem}}.footer{background:#2c3e50;color:#fff;padding:50px 0 20px}.footer-container{max-width:1200px;margin:0 auto 30px;padding:0 20px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:40px}.footer-section h3{font-size:1.5rem;margin-bottom:15px}.footer-section h4{font-size:1.1rem;margin-bottom:15px;color:#ecf0f1}.footer-section p{color:#bdc3c7;line-height:1.6}.footer-section .address{margin-top:20px;padding-top:15px;border-top:1px solid #34495e;font-size:.9rem}.footer-section .address p{margin:3px 0;line-height:1.4}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section ul li{margin-bottom:10px}.footer-section ul li a{color:#bdc3c7;text-decoration:none;transition:color .3s ease}.footer-section ul li a:hover,.logo-highlight{color:#667eea}.footer-bottom{border-top:1px solid #34495e;padding-top:20px;text-align:center;color:#95a5a6;font-size:.9rem}.footer-bottom p{margin:5px 0}.compliance-note{font-size:.85rem;color:#7f8c8d}@media(max-width:768px){.footer-container{grid-template-columns:1fr;gap:30px}.footer-section{text-align:center}}.home{width:100%}.container{max-width:1200px;margin:0 auto;padding:0 20px}.hero{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:100px 0 80px;text-align:center}.hero h1{font-size:3.5rem;font-weight:800;margin-bottom:20px;line-height:1.2}.hero .tagline{font-size:1.5rem;margin-bottom:10px;font-weight:300;max-width:800px;margin-left:auto;margin-right:auto}.hero .subtitle{font-size:1.2rem;margin-bottom:40px;opacity:.9}.cta-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.btn{padding:16px 40px;font-size:1.1rem;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:all .3s ease}.btn-primary{background:#fff;color:#667eea}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 25px #0003}.btn-secondary{background:transparent;color:#fff;border:2px solid white}.btn-secondary:hover{background:#fff;color:#667eea}.btn-large{padding:20px 50px;font-size:1.2rem}.how-it-works{padding:80px 0;background:#f8f9fa}.how-it-works h2{text-align:center;font-size:2.5rem;margin-bottom:60px;color:#333}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.step{text-align:center;padding:30px;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease}.step:hover{transform:translateY(-5px)}.step-number{width:60px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700;margin:0 auto 20px}.step h3{font-size:1.4rem;margin-bottom:15px;color:#333}.step p{color:#666;line-height:1.6}.features{padding:80px 0}.features h2{text-align:center;font-size:2.5rem;margin-bottom:60px;color:#333}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:40px}.feature{padding:30px;border-left:4px solid #667eea;background:#f8f9fa;border-radius:8px}.feature h3{font-size:1.4rem;margin-bottom:15px;color:#333}.feature p{color:#666;line-height:1.6}.cta-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:80px 0;text-align:center}.cta-section h2{font-size:2.5rem;margin-bottom:20px}.cta-section p{font-size:1.2rem;margin-bottom:40px;opacity:.9}.compliance-info{padding:40px 0;background:#f8f9fa;text-align:center}.small-text{font-size:.9rem;color:#666;margin:10px 0;line-height:1.6}.small-text a{color:#667eea;text-decoration:none;margin:0 8px}.small-text a:hover{text-decoration:underline}.consent-flow-section{padding:80px 0;background:#fff}.consent-flow-section h2{text-align:center;font-size:2.5rem;margin-bottom:20px;color:#333}.consent-flow-section .section-intro{text-align:center;font-size:1.2rem;color:#666;margin-bottom:60px;max-width:700px;margin-left:auto;margin-right:auto}.consent-flow{display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap}.consent-step{flex:1;min-width:250px;max-width:300px;text-align:center;padding:30px;background:#f8f9fa;border-radius:12px;box-shadow:0 4px 6px #0000001a}.consent-icon{font-size:3rem;margin-bottom:20px}.consent-step h3{font-size:1.4rem;margin-bottom:15px;color:#333}.consent-step p{color:#666;line-height:1.6;margin-bottom:20px}.consent-step .note-text{font-size:.9rem;color:#888;font-style:italic;margin-bottom:0}.consent-step .btn{margin-top:10px;font-size:.95rem;padding:12px 24px}.consent-arrow{font-size:2.5rem;color:#667eea;font-weight:700}@media(max-width:768px){.hero h1{font-size:2.5rem}.hero .tagline{font-size:1.2rem}.steps,.feature-grid{grid-template-columns:1fr}.consent-flow{flex-direction:column}.consent-arrow{transform:rotate(90deg)}.consent-step{max-width:100%}}.legal-page{max-width:900px;margin:0 auto;padding:60px 20px;line-height:1.8;color:#333}.legal-page h1{font-size:2.5rem;margin-bottom:10px;color:#333}.legal-page .last-updated{color:#666;font-size:.95rem;margin-bottom:40px;font-style:italic}.legal-page section{margin-bottom:40px}.legal-page h2{font-size:1.8rem;color:#333;margin-top:40px;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #667eea}.legal-page h3{font-size:1.3rem;color:#444;margin-top:25px;margin-bottom:15px}.legal-page p{margin-bottom:15px;color:#555}.legal-page ul,.legal-page ol{margin-bottom:20px;padding-left:30px}.legal-page li{margin-bottom:10px;color:#555}.legal-page strong{color:#333;font-weight:600}.legal-page a{color:#667eea;text-decoration:none}.legal-page a:hover{text-decoration:underline}.legal-page .btn{padding:14px 35px;font-size:1rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .3s ease}.legal-page .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.legal-page .btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}@media(max-width:768px){.legal-page{padding:40px 15px}.legal-page h1{font-size:2rem}.legal-page h2{font-size:1.5rem}.legal-page h3{font-size:1.2rem}}.consent-page{min-height:calc(100vh - 200px);padding:40px 20px;background:#f8f9fa}.consent-container{max-width:1000px;margin:0 auto}.consent-header{text-align:center;margin-bottom:40px}.consent-header h1{font-size:2.5rem;color:#333;margin-bottom:10px}.consent-header .subtitle{font-size:1.2rem;color:#666}.consent-content{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:40px}.info-section{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.info-section h2{font-size:1.6rem;color:#333;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #667eea}.info-section h3{font-size:1.3rem;color:#444;margin-top:25px;margin-bottom:15px}.info-section h4{font-size:1.1rem;color:#555;margin-bottom:10px}.info-section ol{padding-left:25px;line-height:1.8;color:#555}.info-section ol li{margin-bottom:12px}.info-section ul{padding-left:25px;line-height:1.6;color:#555}.info-section ul li{margin-bottom:8px}.compliance-notice{background:#fff3cd;border-left:4px solid #ffc107;padding:20px;margin-top:25px;border-radius:6px}.compliance-notice h3{color:#856404;margin-top:0;font-size:1.2rem}.compliance-notice p{color:#856404;margin-bottom:10px;line-height:1.6}.sender-info{background:#e7f3ff;border-left:4px solid #2196F3;padding:20px;margin-bottom:25px;border-radius:6px}.sender-info h3{margin-top:0;color:#0d47a1}.sender-info p{margin:8px 0;color:#1565c0}.agreement-details{margin-top:20px}.detail-item{margin-bottom:25px;padding-bottom:20px;border-bottom:1px solid #eee}.detail-item:last-child{border-bottom:none}.detail-item h4{color:#667eea;margin-bottom:10px}.detail-item p,.detail-item ul{color:#555;line-height:1.6}.two-step-notice{background:#d1ecf1;border-left:4px solid #17a2b8;padding:20px;margin-top:25px;border-radius:6px}.two-step-notice h3{color:#0c5460;margin-top:0}.two-step-notice p{color:#0c5460;line-height:1.6;margin:0}.consent-form{background:#fff;padding:30px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.consent-form h2{font-size:1.6rem;color:#333;margin-bottom:25px;padding-bottom:10px;border-bottom:2px solid #667eea}.form-group{margin-bottom:25px}.form-group label{display:block;font-weight:600;color:#333;margin-bottom:8px;font-size:1rem}.form-group input[type=text],.form-group input[type=email],.form-group input[type=tel]{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-group input[type=text]:focus,.form-group input[type=email]:focus,.form-group input[type=tel]:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group small{display:block;margin-top:6px;color:#666;font-size:.85rem}.checkbox-group{margin-bottom:25px}.checkbox-label{display:flex;align-items:flex-start;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{margin-top:4px;margin-right:12px;width:20px;height:20px;cursor:pointer;flex-shrink:0}.checkbox-text{color:#555;line-height:1.6;font-size:.95rem}.checkbox-text strong{color:#333;display:block;margin-bottom:6px}.checkbox-text ul{margin-top:10px;padding-left:20px}.checkbox-text ul li{margin-bottom:6px}.checkbox-text a{color:#667eea;text-decoration:underline}.submit-btn{width:100%;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.submit-btn:disabled{background:#ccc;cursor:not-allowed;transform:none}.form-footer{margin-top:20px;padding-top:20px;border-top:1px solid #eee;font-size:.85rem;color:#666;line-height:1.6;text-align:center}.success-message{background:#fff;padding:60px 40px;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;max-width:700px;margin:0 auto}.success-icon{width:80px;height:80px;background:#28a745;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;margin:0 auto 30px}.success-message h1{color:#333;font-size:2.5rem;margin-bottom:10px}.success-message h2{color:#667eea;font-size:1.6rem;margin-bottom:30px;font-weight:500}.success-content{text-align:left;margin-top:30px}.success-content>p{font-size:1.1rem;color:#555;margin-bottom:25px}.sms-preview{background:#f8f9fa;padding:25px;border-radius:8px;margin:25px 0}.sms-label{font-weight:600;color:#333;margin-bottom:15px;font-size:.95rem}.sms-bubble{background:#fff;border:2px solid #667eea;border-radius:18px;padding:15px 20px;font-size:.95rem;color:#333;line-height:1.6;box-shadow:0 2px 4px #0000001a}.instruction{background:#fff3cd;border-left:4px solid #ffc107;padding:15px 20px;margin:25px 0;border-radius:6px}.instruction strong{color:#856404}.help-text{margin-top:30px;padding-top:25px;border-top:1px solid #eee}.help-text p{font-weight:600;color:#333;margin-bottom:10px}.help-text ul{padding-left:25px;color:#555}.help-text ul li{margin-bottom:8px}.help-text a{color:#667eea}@media(max-width:968px){.consent-content{grid-template-columns:1fr}.consent-header h1{font-size:2rem}.success-message{padding:40px 25px}.success-message h1{font-size:2rem}.success-icon{width:60px;height:60px;font-size:2rem}}.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}*{box-sizing:border-box}
