:root{--color-primary:#5e5549;--color-secondary:#faf7f2;--color-accent:#b7aa9a;--color-light-beige:#f5efe8;--color-beige:#e8e0d5;--color-beige-dark:#d6ccbf;--color-taupe:#8f8375;--font-heading:'Playfair Display',serif;--font-body:'Raleway',sans-serif;--transition:all 0.5s ease}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--font-body);color:var(--color-primary);background-color:var(--color-secondary);line-height:1.6;overflow-x:hidden}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.section{padding:80px 0;position:relative}
.section-title{font-family:var(--font-heading);font-size:2.8rem;font-weight:700;text-align:center;margin-bottom:60px;position:relative;color:var(--color-primary)}
.section-title::after{content:'';position:absolute;bottom:-15px;left:50%;transform:translateX(-50%);width:80px;height:2px;background:linear-gradient(90deg,var(--color-beige),var(--color-taupe),var(--color-beige))}
#navbar{position:fixed;top:0;left:0;width:100%;background-color:rgba(250,247,242,0.95);box-shadow:0 2px 10px rgba(0,0,0,0.05);z-index:1000;padding:15px 0;transition:var(--transition)}
#navbar.scrolled{padding:10px 0;background-color:rgba(250,247,242,0.98)}
.nav-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:0 20px}
.nav-logo{font-family:var(--font-heading);font-size:1.8rem;font-weight:700;color:var(--color-primary)}
.nav-menu{display:flex;list-style:none}
.nav-menu li{margin-left:30px}
.nav-menu a{text-decoration:none;color:var(--color-primary);font-weight:500;font-size:1rem;transition:var(--transition);position:relative}
.nav-menu a:hover{color:var(--color-taupe)}
.nav-menu a::after{content:'';position:absolute;bottom:-5px;left:0;width:0;height:1px;background-color:var(--color-taupe);transition:var(--transition)}
.nav-menu a:hover::after{width:100%}
.hamburger{display:none;flex-direction:column;cursor:pointer}
.hamburger span{width:25px;height:2px;background-color:var(--color-primary);margin:3px 0;transition:var(--transition)}
.hero{height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;background:url('img/fondoPri.jpeg') no-repeat center center/cover;background-attachment:fixed}
.hero::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(250,247,242,0.4);mix-blend-mode:normal;pointer-events:none;z-index:1}.hero::after{content:'';position:absolute;top:0;left:0;width:100%;height:70%;background:linear-gradient(to bottom,rgba(0,0,0,0.4) 0%,rgba(0,0,0,0.2) 30%,rgba(0,0,0,0.1) 60%,rgba(0,0,0,0) 100%);pointer-events:none;z-index:1}
.hero-container{position:relative;z-index:2;width:100%;padding-top:5vh}
.hero-content{max-width:800px;margin:0 auto;padding:20px;position:relative;z-index:3}
.hero-content h1{font-family:var(--font-heading);font-size:4.5rem;font-weight:700;margin-bottom:20px;letter-spacing:2px;color:#3a2e25}.hero-content .date{font-size:1.8rem;font-weight:400;margin-bottom:15px;letter-spacing:1px;color:var(--color-taupe)}
.image-frame{position:relative;padding:15px;background:linear-gradient(145deg,var(--color-beige),var(--color-light-beige));border-radius:4px;box-shadow:0 15px 30px rgba(0,0,0,0.05);transition:var(--transition)}
.image-frame::before{content:'';position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px solid rgba(255,255,255,0.5);pointer-events:none;z-index:2}
.image-frame:hover{transform:translateY(-5px);box-shadow:0 20px 40px rgba(0,0,0,0.1)}
.image-frame img{width:100%;height:auto;display:block;border-radius:2px;filter:sepia(0.1) contrast(1.02);transition:var(--transition)}
.image-frame:hover img{filter:sepia(0) contrast(1.05)}
.story-content{display:flex;align-items:center;justify-content:space-between;gap:60px}
.story-text{flex:1;font-size:1.1rem;line-height:1.8}
.story-text p{margin-bottom:20px}
.story-image{flex:1}
.ceremony{background-color:var(--color-light-beige);background-image:url('data:image/svg+xml;utf8,<svg width="80" height="80" viewBox="0 0 80 80" xmlns="http://www.w3.org/2000/svg"><circle cx="40" cy="40" r="2" fill="%23d6ccbf" opacity="0.2"/></svg>')}
.ceremony-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:40px;margin-top:40px}
.detail-card{background-color:var(--color-secondary);padding:40px 30px;border-radius:4px;box-shadow:0 5px 15px rgba(0,0,0,0.03);text-align:center;transition:var(--transition);border:1px solid var(--color-beige)}
.detail-card:hover{transform:translateY(-10px);box-shadow:0 15px 30px rgba(0,0,0,0.08);border-color:var(--color-accent)}
.detail-icon{font-size:2.5rem;margin-bottom:20px;color:var(--color-primary)}
.detail-card h3{font-family:var(--font-heading);font-size:1.5rem;margin-bottom:15px;color:var(--color-primary)}
.detail-card p{color:var(--color-taupe)}
.timeline{position:relative;max-width:800px;margin:0 auto;padding-left:0}
.timeline::before{content:'';position:absolute;top:0;bottom:0;left:20px;width:2px;background:linear-gradient(to bottom,var(--color-beige-dark),var(--color-accent),var(--color-beige-dark));transform:translateX(0)}
.timeline-item{display:flex;margin-bottom:50px;position:relative;align-items:flex-start}
.timeline-time{flex:0 0 80px;font-size:1.2rem;font-weight:600;text-align:left;padding:5px 10px 0 0;position:relative;z-index:2;background-color:transparent;color:var(--color-taupe)}
.timeline-content{flex:1;padding:25px;background-color:var(--color-secondary);border-radius:4px;box-shadow:0 5px 15px rgba(0,0,0,0.03);position:relative;margin-left:20px;min-height:120px;display:flex;flex-direction:column;justify-content:center;border:1px solid var(--color-beige)}
.timeline-content h3{font-family:var(--font-heading);font-size:1.3rem;margin-bottom:8px;color:var(--color-primary)}
.timeline-content p{color:var(--color-taupe);font-size:0.95rem}
.timeline-content::before{content:'';position:absolute;top:50%;left:-10px;width:20px;height:20px;background-color:var(--color-accent);border-radius:50%;transform:translateY(-50%);border:3px solid var(--color-secondary);z-index:2}
.gifts-content{display:flex;align-items:center;gap:60px}
.gifts-text{flex:1}
.gifts-image{flex:1}
.confirmation{margin-top:40px;padding:30px;background-color:var(--color-light-beige);border-radius:4px;border:1px solid var(--color-beige)}
.confirmation h3{font-family:var(--font-heading);font-size:1.5rem;margin-bottom:15px;color:var(--color-primary)}
.email{display:flex;align-items:center;margin:20px 0}
.email i{margin-right:10px;color:var(--color-accent)}
.email a{color:var(--color-primary);text-decoration:none;font-weight:500}
.email a:hover{color:var(--color-taupe);text-decoration:underline}
.faq{background-color:var(--color-light-beige);background-image:url('data:image/svg+xml;utf8,<svg width="60" height="60" viewBox="0 0 60 60" xmlns="http://www.w3.org/2000/svg"><path d="M30 10 L50 30 L30 50 L10 30 Z" fill="none" stroke="%23d6ccbf" stroke-width="0.5" opacity="0.2"/></svg>')}
.faq-container{max-width:800px;margin:0 auto}
.faq-item{background-color:var(--color-secondary);margin-bottom:15px;border-radius:4px;overflow:hidden;box-shadow:0 3px 10px rgba(0,0,0,0.02);border:1px solid var(--color-beige)}
.faq-question{padding:20px 30px;display:flex;justify-content:space-between;align-items:center;cursor:pointer}
.faq-question h3{font-family:var(--font-heading);font-size:1.2rem;font-weight:600;color:var(--color-primary)}
.faq-question i{transition:var(--transition);color:var(--color-accent)}
.faq-item.active .faq-question i{transform:rotate(180deg)}
.faq-answer{padding:0 30px;max-height:0;overflow:hidden;transition:var(--transition)}
.faq-item.active .faq-answer{padding:0 30px 20px;max-height:300px}
.contacts-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:30px;margin-top:40px}
.contact-card{background-color:var(--color-secondary);padding:40px 30px;border-radius:4px;text-align:center;box-shadow:0 5px 15px rgba(0,0,0,0.03);transition:var(--transition);border:1px solid var(--color-beige)}
.contact-card:hover{transform:translateY(-10px);box-shadow:0 15px 30px rgba(0,0,0,0.08);border-color:var(--color-accent)}
.contact-icon{font-size:2.5rem;margin-bottom:20px;color:var(--color-primary)}
.contact-card h3{font-family:var(--font-heading);font-size:1.3rem;margin-bottom:20px;color:var(--color-primary)}
.contact-info{display:flex;align-items:center;justify-content:center;margin-top:10px}
.contact-info i{margin-right:10px;color:var(--color-accent)}
.contact-info a{color:var(--color-taupe);text-decoration:none}
.contact-info a:hover{color:var(--color-primary);text-decoration:underline}
.useful-info{background:linear-gradient(135deg,var(--color-beige),var(--color-beige-dark));padding:60px 0}
.useful-info-card{max-width:700px;margin:0 auto;background-color:var(--color-secondary);padding:50px;border-radius:4px;text-align:center;box-shadow:0 20px 40px rgba(0,0,0,0.08);border:1px solid var(--color-beige)}
.useful-info-card h2{font-family:var(--font-heading);font-size:2.5rem;color:var(--color-primary);margin-bottom:30px}
.useful-info-card p{margin-bottom:20px;font-size:1.1rem;color:var(--color-taupe)}
.useful-info-card .thanks{font-weight:600;color:var(--color-primary);margin-top:30px}
.useful-info-card .copyright{font-size:0.9rem;margin-top:40px;color:var(--color-accent)}
footer{background-color:var(--color-primary);color:var(--color-secondary);padding:60px 0 30px;text-align:center}
footer p{margin-bottom:15px}
footer .hashtag{color:var(--color-beige);font-size:1.1rem}
.footer-nav{margin:30px 0}
.footer-nav a{color:var(--color-beige);text-decoration:none;margin:0 10px;transition:var(--transition)}
.footer-nav a:hover{color:var(--color-secondary)}
.copyright i{color:#e6b3b3;margin:0 5px}
.fade-in{opacity:0;transform:translateY(30px);transition:opacity 1s ease,transform 1s ease}
.fade-in.visible{opacity:1;transform:translateY(0)}
.fade-in-delay{opacity:0;transform:translateY(30px);transition:opacity 1s ease 0.3s,transform 1s ease 0.3s}
.fade-in-delay.visible{opacity:1;transform:translateY(0)}
.fade-in-delay-2{opacity:0;transform:translateY(30px);transition:opacity 1s ease 0.6s,transform 1s ease 0.6s}
.fade-in-delay-2.visible{opacity:1;transform:translateY(0)}
.fade-up{opacity:0;transform:translateY(50px);transition:opacity 0.8s ease,transform 0.8s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}
.fade-left{opacity:0;transform:translateX(-50px);transition:opacity 0.8s ease,transform 0.8s ease}
.fade-left.visible{opacity:1;transform:translateX(0)}
.fade-right{opacity:0;transform:translateX(50px);transition:opacity 0.8s ease,transform 0.8s ease}
.fade-right.visible{opacity:1;transform:translateX(0)}
.rsvp-form{text-align:left;margin:25px 0 10px;padding:20px 0;border-top:1px dashed var(--color-beige-dark);border-bottom:1px dashed var(--color-beige-dark)}
.form-group{margin-bottom:20px}
.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--color-primary);font-size:0.95rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 15px;border:1px solid var(--color-beige);border-radius:4px;font-family:var(--font-body);font-size:1rem;background-color:#fff;transition:var(--transition);resize:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px rgba(183,170,154,0.15)}
.form-group small{display:block;margin-top:5px;font-size:0.8rem;color:var(--color-taupe)}
.submit-btn{background-color:var(--color-primary);color:#fff;border:none;padding:15px 25px;font-size:1rem;font-weight:500;border-radius:4px;cursor:pointer;width:100%;transition:var(--transition);letter-spacing:1px;margin:10px 0;text-transform:uppercase}
.submit-btn:hover{background-color:var(--color-taupe);transform:translateY(-2px);box-shadow:0 5px 15px rgba(0,0,0,0.1)}
.submit-btn:active{transform:translateY(0)}
.btn-elegante{display:inline-flex;align-items:center;justify-content:center;gap:12px;background:linear-gradient(145deg,var(--color-beige),var(--color-beige-dark));color:var(--color-primary);text-decoration:none;padding:16px 32px;font-size:1.1rem;font-weight:500;letter-spacing:1px;border-radius:40px;transition:var(--transition);border:1px solid rgba(94,85,73,0.1);box-shadow:0 8px 20px rgba(94,85,73,0.1);width:100%}
.btn-elegante:hover{background:var(--color-primary);color:var(--color-secondary);transform:translateY(-3px);box-shadow:0 15px 30px rgba(94,85,73,0.3)}
.btn-elegante i{font-size:1rem;transition:transform 0.3s ease;color:inherit}
.btn-elegante:hover i{transform:translateX(5px)}
.faq-row{display:flex;gap:40px;align-items:center;min-height:500px}
.faq-image-col{flex:1}
.faq-items-col{flex:1;display:flex;align-items:center}
.faq-item.expanded .faq-answer{max-height:300px !important;padding:0 30px 20px !important}
.faq-item.expanded .faq-question i{display:none}
.faq-item.expanded .faq-question{cursor:default}
.faq-item.expanded .faq-question:hover{background-color:transparent}
@media (max-width:992px){.story-content,.gifts-content{flex-direction:column;gap:40px}.section-title{font-size:2.5rem}.hero-content h1{font-size:3.8rem}}
@media (max-width:768px){.nav-menu{position:fixed;top:70px;left:-100%;width:100%;height:calc(100vh - 70px);flex-direction:column;background-color:var(--color-secondary);text-align:center;transition:var(--transition);box-shadow:0 10px 20px rgba(0,0,0,0.05);padding:40px 0;overflow-y:auto}.nav-menu.active{left:0}.nav-menu li{margin:20px 0}.nav-menu a{font-size:1.2rem}.hamburger{display:flex}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.hero{background-attachment:scroll}.hero::after{height:80%}.hero-content h1{font-size:3.2rem}.hero-content .date{font-size:1.5rem}.hero-container{padding-top:2vh}.timeline-item{margin-bottom:30px}.timeline-time{flex:0 0 70px;font-size:1.1rem}.timeline-content{padding:20px;margin-left:15px}.timeline-content h3{font-size:1.2rem}.section{padding:60px 0}.section-title{font-size:2.2rem;margin-bottom:40px}.ceremony-details{gap:25px}.detail-card{padding:30px 20px}.detail-card h3{font-size:1.3rem}.contacts-container{grid-template-columns:1fr;gap:20px}.contact-card{padding:30px 20px}.faq-question{padding:15px 20px}.faq-question h3{font-size:1.1rem}.faq-answer{padding:0 20px}.faq-item.active .faq-answer{padding:0 20px 15px}.useful-info-card{padding:30px 20px}.useful-info-card h2{font-size:2rem}.rsvp-form{padding:15px 0}.form-group input,.form-group select,.form-group textarea{padding:10px 12px}footer{padding:40px 0 20px}.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 15px}.footer-nav a{margin:0;font-size:0.85rem}.faq-row{flex-direction:column;gap:30px;min-height:auto}.faq-image-col,.faq-items-col{width:100%}.faq-item.expanded .faq-answer{padding:0 20px 15px !important}}
@media (max-width:480px){.section-title{font-size:1.9rem}.hero-content h1{font-size:2.5rem}.hero-content .date{font-size:1.3rem}.hero::after{height:85%}.timeline-time{flex:0 0 60px;font-size:1rem}.timeline-content{padding:15px;min-height:auto}.timeline-content h3{font-size:1.1rem}.timeline-content p{font-size:0.9rem}.timeline-content::before{width:16px;height:16px;left:-8px}.detail-card,.contact-card{padding:25px 15px}.detail-icon{font-size:2rem}.email a{font-size:0.9rem;word-break:break-all}.useful-info-card h2{font-size:1.8rem}.useful-info-card p{font-size:1rem}.btn-elegante{padding:14px 24px;font-size:1rem;gap:8px}}
@media (max-width:360px){.hero-content h1{font-size:2.2rem}.hero-content .date{font-size:1.1rem}.section-title{font-size:1.7rem}.timeline-time{flex:0 0 50px;font-size:0.9rem}.timeline-content h3{font-size:1rem}}
img{max-width:100%;height:auto}
@media (hover:none) and (pointer:coarse){.nav-menu a,.detail-card,.contact-card,.faq-question,.submit-btn{cursor:default;-webkit-tap-highlight-color:rgba(183,170,154,0.3)}.detail-card:hover,.contact-card:hover{transform:none}.detail-card:active,.contact-card:active{transform:scale(0.98)}}
.confirmation-subtitle{font-size:1rem;color:var(--color-taupe);margin-bottom:20px;font-style:italic}
.form-row{display:flex;gap:15px;margin-bottom:20px}
.form-group.half{flex:1;margin-bottom:0}
.confirmation-divider{text-align:center;margin:25px 0 20px;position:relative}
.confirmation-divider::before{content:'';position:absolute;top:50%;left:0;width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--color-beige-dark),transparent)}
.confirmation-divider span{background:var(--color-light-beige);padding:5px 25px;border-radius:40px;font-size:0.9rem;color:var(--color-taupe);position:relative;border:1px solid var(--color-beige);letter-spacing:0.5px}
.email-note{font-size:0.85rem;color:var(--color-taupe);margin-top:8px;text-align:center}