*{margin:0;padding:0;box-sizing:border-box}
:root{--primary:#5AA469;--primary-dark:#4a8a59;--text:#333333;--text-light:#666666;--bg:#ffffff;--bg-light:#f8f9fa;--border:#e9ecef;--shadow:0 2px 15px rgba(0,0,0,0.08)}
html{scroll-behavior:smooth}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;font-size:16px;line-height:1.6;color:var(--text);background:var(--bg)}
h1,h2,h3{font-weight:600;line-height:1.3;margin-bottom:1rem;color:var(--text)}
h1{font-size:2.25rem}
h2{font-size:1.75rem}
h3{font-size:1.25rem}
p{margin-bottom:1rem;color:var(--text-light)}
a{color:var(--primary);text-decoration:none;transition:color 0.3s}
a:hover{color:var(--primary-dark)}
img{max-width:100%;height:auto;display:block}
.header{position:fixed;top:0;left:0;right:0;background:var(--bg);box-shadow:var(--shadow);z-index:1000;padding:0.75rem 0}
.header .navbar-brand{font-size:1.5rem;font-weight:700;color:var(--primary)}
.header .navbar-brand:hover{color:var(--primary-dark)}
.header .nav-link{color:var(--text);font-size:0.9rem;padding:0.5rem 1rem;transition:color 0.3s}
.header .nav-link:hover{color:var(--primary)}
.hero{padding:8rem 0 5rem;background:linear-gradient(135deg,var(--bg-light) 0%,var(--bg) 100%)}
.hero h1{margin-bottom:1.5rem}
.hero p{font-size:1.1rem;max-width:600px}
.hero-img{border-radius:12px;box-shadow:var(--shadow)}
.section{padding:5rem 0}
.section-light{background:var(--bg-light)}
.section-title{text-align:center;margin-bottom:3rem}
.section-title h2{position:relative;display:inline-block;padding-bottom:1rem}
.section-title h2::after{content:"";position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:3px;background:var(--primary);border-radius:2px}
.section-title p{max-width:700px;margin:1rem auto 0}
.card-info{background:var(--bg);border-radius:12px;box-shadow:var(--shadow);padding:2rem;height:100%;transition:transform 0.3s,box-shadow 0.3s}
.card-info:hover{transform:translateY(-5px);box-shadow:0 8px 25px rgba(0,0,0,0.12)}
.card-info h3{color:var(--primary);margin-bottom:1rem}
.card-info-icon{width:60px;height:60px;background:var(--bg-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem}
.card-info-icon svg{width:30px;height:30px;stroke:var(--primary)}
.card-img{border-radius:12px;overflow:hidden;margin-bottom:1.5rem}
.card-img img{width:100%;height:200px;object-fit:cover}
.list-check{list-style:none;padding:0}
.list-check li{position:relative;padding-left:1.75rem;margin-bottom:0.75rem;color:var(--text-light)}
.list-check li::before{content:"";position:absolute;left:0;top:0.5rem;width:8px;height:8px;background:var(--primary);border-radius:50%}
.table-info{background:var(--bg);border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.table-info th{background:var(--primary);color:var(--bg);font-weight:600;border:none}
.table-info td{border-color:var(--border);vertical-align:middle}
.accordion-custom .card{border:none;border-radius:12px;margin-bottom:1rem;box-shadow:var(--shadow);overflow:hidden}
.accordion-custom .card-header{background:var(--bg);border:none;padding:0}
.accordion-custom .btn-link{color:var(--text);font-weight:600;text-decoration:none;padding:1.25rem 1.5rem;display:block;width:100%;text-align:left;position:relative}
.accordion-custom .btn-link::after{content:"+";position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);font-size:1.5rem;color:var(--primary);transition:transform 0.3s}
.accordion-custom .btn-link[aria-expanded="true"]::after{content:"-"}
.accordion-custom .card-body{padding:0 1.5rem 1.5rem;color:var(--text-light)}
.btn-primary-custom{background:var(--primary);color:var(--bg);border:none;padding:0.875rem 2rem;border-radius:8px;font-weight:600;transition:background 0.3s,transform 0.3s}
.btn-primary-custom:hover{background:var(--primary-dark);color:var(--bg);transform:translateY(-2px)}
.btn-outline-custom{background:transparent;color:var(--primary);border:2px solid var(--primary);padding:0.875rem 2rem;border-radius:8px;font-weight:600;transition:all 0.3s}
.btn-outline-custom:hover{background:var(--primary);color:var(--bg)}
.form-control-custom{border:2px solid var(--border);border-radius:8px;padding:0.875rem 1rem;transition:border-color 0.3s,box-shadow 0.3s}
.form-control-custom:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(90,164,105,0.15);outline:none}
.context-box{background:var(--bg-light);border-left:4px solid var(--primary);padding:2rem;border-radius:0 12px 12px 0;margin:2rem 0}
.context-box h3{color:var(--primary);margin-bottom:1rem}
.footer{background:var(--text);color:var(--bg);padding:3rem 0 1.5rem}
.footer h3{color:var(--bg);font-size:1.1rem;margin-bottom:1.5rem}
.footer p,.footer a{color:rgba(255,255,255,0.7);font-size:0.9rem}
.footer a:hover{color:var(--bg)}
.footer-links{list-style:none;padding:0}
.footer-links li{margin-bottom:0.5rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);margin-top:2rem;padding-top:1.5rem;text-align:center}
.footer-bottom p{margin:0;font-size:0.85rem}
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:var(--text);color:var(--bg);padding:1.25rem;z-index:1001;display:none}
.cookie-banner.show{display:block}
.cookie-banner p{margin:0 0 1rem;font-size:0.9rem;color:rgba(255,255,255,0.9)}
.cookie-banner .btn{margin-right:0.5rem;margin-bottom:0.5rem}
.modal-policy .modal-content{border-radius:12px;border:none}
.modal-policy .modal-header{border-bottom:1px solid var(--border);padding:1.5rem}
.modal-policy .modal-body{padding:1.5rem;max-height:60vh;overflow-y:auto}
.modal-policy .modal-footer{border-top:1px solid var(--border);padding:1rem 1.5rem}
.thank-you-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--bg);padding:3rem;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,0.2);z-index:1002;display:none;text-align:center;max-width:400px}
.thank-you-popup.show{display:block}
.thank-you-popup h3{color:var(--primary);margin-bottom:1rem}
.overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.5);z-index:1001;display:none}
.overlay.show{display:block}
@media(max-width:991px){.header .navbar-collapse{background:var(--bg);padding:1rem;margin-top:0.5rem;border-radius:8px;box-shadow:var(--shadow)}}
@media(max-width:767px){h1{font-size:1.75rem}h2{font-size:1.5rem}.hero{padding:6rem 0 3rem}.section{padding:3rem 0}.card-info{padding:1.5rem}}
