*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#333;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.hero-section{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.hero-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="1" fill="white" opacity="0.1"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');animation:sparkle 3s ease-in-out infinite;z-index:1}.hero-section:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 400"><g opacity="0.15"><circle cx="200" cy="100" r="40" fill="white"/><circle cx="220" cy="90" r="30" fill="white"/><circle cx="180" cy="90" r="25" fill="white"/><circle cx="600" cy="150" r="35" fill="white"/><circle cx="620" cy="140" r="28" fill="white"/><circle cx="580" cy="140" r="22" fill="white"/><circle cx="1000" cy="80" r="45" fill="white"/><circle cx="1020" cy="70" r="35" fill="white"/><circle cx="980" cy="70" r="30" fill="white"/></g></svg>');animation:floatClouds 20s linear infinite;z-index:1}@keyframes sparkle{0%,to{opacity:1}50%{opacity:1}}@keyframes floatClouds{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes flyPlanes{0%{background-position:-1200px 0}to{background-position:1200px 0}}.hero-section:before,.hero-section:after{will-change:transform,opacity;transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.animated-airplanes{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:2;overflow:hidden}.airplane{position:absolute;color:#fff9;font-size:2rem;animation:flyAcross 20s linear infinite;will-change:transform,opacity}.airplane-1{top:20%;animation:flyAcross1 25s linear infinite}.airplane-2{top:50%;animation:flyAcross2 30s linear infinite 8s}.airplane-3{top:80%;animation:flyAcross3 22s linear infinite 15s}@keyframes flyAcross1{0%{transform:translate(-150px);opacity:0}5%{opacity:.6}95%{opacity:.6}to{transform:translate(calc(100vw + 150px));opacity:0}}@keyframes flyAcross2{0%{transform:translate(-150px);opacity:0}5%{opacity:.6}95%{opacity:.6}to{transform:translate(calc(100vw + 150px));opacity:0}}@keyframes flyAcross3{0%{transform:translate(-150px);opacity:0}5%{opacity:.6}95%{opacity:.6}to{transform:translate(calc(100vw + 150px));opacity:0}}.hero-section{background-image:none;animation:twinkleStars 8s ease-in-out infinite;will-change:background-position,opacity;transform:translateZ(0)}.hero-content{text-align:center;color:#fff;z-index:3;position:relative;max-width:800px;padding:2rem;will-change:transform;transform:translateZ(0);animation:gentleFloat 6s ease-in-out infinite;text-shadow:0 2px 4px rgba(0,0,0,.5)}@keyframes gentleFloat{0%,to{transform:translateY(0) translateZ(0)}50%{transform:translateY(-5px) translateZ(0)}}@keyframes twinkleStars{0%,to{opacity:1}50%{opacity:1}}.hero-section{transform:translateZ(0);-webkit-transform:translateZ(0);-moz-transform:translateZ(0);-ms-transform:translateZ(0);-o-transform:translateZ(0);-webkit-backface-visibility:hidden;-moz-backface-visibility:hidden;-ms-backface-visibility:hidden;backface-visibility:hidden;contain:layout style paint}.hero-title{font-size:4rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 8px rgba(0,0,0,.6);animation:fadeInUp 1s ease-out}.hero-subtitle{font-size:1.5rem;font-weight:300;margin-bottom:2rem;animation:fadeInUp 1s ease-out .3s both;text-shadow:1px 1px 4px rgba(0,0,0,.5)}.storyline-section{margin:3rem 0;animation:fadeInUp 1s ease-out .6s both}.storyline-title{font-size:2rem;font-weight:600;margin-bottom:2rem;text-align:center;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.storyline-content{display:grid;grid-template-columns:2fr 1fr;gap:3rem;align-items:start;max-width:1000px;margin:0 auto}.storyline-text{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;border:1px solid rgba(255,255,255,.2)}.storyline-text p{font-size:1.1rem;line-height:1.7;margin-bottom:1.5rem;color:#fff}.storyline-text p:last-child{margin-bottom:0}.storyline-text em{font-style:italic;color:gold;font-weight:500}.storyline-image{display:flex;justify-content:center;align-items:stretch;height:100%}.friends-photo{width:100%;height:100%;object-fit:cover;border-radius:20px;box-shadow:0 8px 32px #0000004d;border:3px solid rgba(255,255,255,.2);transition:all .3s ease}.friends-photo:hover{transform:scale(1.02);box-shadow:0 12px 40px #0006}@media (max-width: 768px){.storyline-content{grid-template-columns:1fr;gap:2rem}.storyline-text{padding:1.5rem}.storyline-text p{font-size:1rem}.storyline-title{font-size:1.5rem}.friends-photo{height:300px;width:100%;max-width:250px}}@media (max-width: 480px){.storyline-section{margin:2rem 0}.storyline-text{padding:1rem}.friends-photo{height:250px;width:100%;max-width:200px}}.intro-content{margin-bottom:2rem;animation:fadeInUp 1s ease-out .5s both}.intro-text{font-size:1.2rem;line-height:1.6;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto}.quick-details{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}.quick-detail{display:flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.8rem 1.2rem;border-radius:25px;border:1px solid rgba(255,255,255,.2);transition:transform .3s ease}.quick-detail:hover{transform:translateY(-2px)}.detail-icon{font-size:1.2rem}.quick-detail span:last-child{font-weight:500;font-size:.95rem}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.countdown-container{margin-top:2rem;animation:fadeInUp 1s ease-out .7s both}.countdown-section{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:2rem;border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;text-align:center}.countdown-title{font-size:2rem;font-weight:600;text-align:center;margin-bottom:1.5rem;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.countdown{display:flex;justify-content:center;gap:1rem;margin-top:0}.countdown-item{background:rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:10px;padding:1rem .8rem;text-align:center;min-width:70px;border:1px solid rgba(255,255,255,.2);transition:transform .3s ease}.countdown-item:hover{transform:translateY(-3px)}.countdown-number{display:block;font-size:1.8rem;font-weight:700;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.countdown-label{display:block;font-size:.7rem;color:#fffc;text-transform:uppercase;letter-spacing:1px;margin-top:.3rem}.invitation-section{background:white;padding:4rem 0;min-height:100vh}.container{max-width:1200px;margin:0 auto;padding:0 2rem}.section-title{font-size:3rem;text-align:center;margin-bottom:3rem;color:#333;font-weight:300}.voting-section{margin-bottom:4rem;padding:3rem 2rem;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-radius:20px}.voting-deadline-small{display:flex;justify-content:center;margin-bottom:2rem}.voting-deadline-small .voting-deadline{min-width:220px;padding:.8rem 1.2rem;font-size:.95rem;background:rgba(0,0,0,.4);border:2px solid rgba(255,255,255,.5);box-shadow:0 6px 20px #0000004d}.voting-deadline-small .deadline-label{font-size:.85rem;font-weight:700;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.8)}.voting-deadline-small .deadline-countdown .countdown-item{min-width:1.8rem;padding:.4rem .3rem;background:rgba(0,0,0,.3);border:2px solid rgba(255,255,255,.4);box-shadow:0 3px 10px #0000004d}.voting-deadline-small .deadline-countdown .countdown-number{font-size:1rem;font-weight:900;color:#fff;text-shadow:0 3px 6px rgba(0,0,0,.8)}.voting-deadline-small .deadline-countdown .countdown-label{font-size:.6rem;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.8)}.voting-title{text-align:center;font-size:2.5rem;margin-bottom:1rem;color:#333;font-weight:300}.voting-subtitle{text-align:center;font-size:1.2rem;color:#6c757d;margin-bottom:3rem}.destinations-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-bottom:3rem;padding:0 1rem}.destination-card{background:white;border-radius:15px;padding:1.8rem;box-shadow:0 5px 15px #0000001a;transition:all .3s ease;cursor:pointer;border:2px solid transparent;min-height:280px;display:flex;flex-direction:column;position:relative;overflow:hidden}.destination-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px #00000026}.destination-card.voted{border-color:#667eea;background:linear-gradient(135deg,#f8f9ff 0%,#e9ecef 100%)}.destination-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.destination-image{position:relative;width:80px;height:80px;border-radius:50%;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.destination-img{width:100%;height:100%;object-fit:cover;border-radius:50%}.destination-emoji{font-size:2.5rem;display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-radius:50%}.destination-info h4{font-size:1.3rem;color:#333;margin:0}.destination-info p{color:#6c757d;margin:0;font-size:.9rem}.destination-creator{color:#667eea!important;font-size:.8rem!important;font-weight:500!important;margin-top:.3rem!important}.vote-count{margin-left:auto;text-align:center}.vote-number{display:block;font-size:1.5rem;font-weight:700;color:#667eea}.vote-label{font-size:.8rem;color:#6c757d}.destination-description{color:#6c757d;line-height:1.6;margin-bottom:1rem}.destination-highlights{display:flex;flex-wrap:wrap;gap:.3rem;margin-bottom:1.2rem;max-height:50px;overflow:hidden;position:relative}.destination-highlights:after{content:"";position:absolute;bottom:0;right:0;width:25px;height:15px;background:linear-gradient(90deg,transparent,white);pointer-events:none}.highlight-tag{background:rgba(102,126,234,.06);color:#667eea;padding:.2rem .5rem;border-radius:10px;font-size:.7rem;font-weight:500;border:1px solid rgba(102,126,234,.1);white-space:nowrap;flex-shrink:0;opacity:.8}.vote-button{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:.8rem 1.5rem;border-radius:25px;text-align:center;font-weight:600;transition:all .3s ease;margin-top:auto;width:100%;border:none;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:48px;display:flex;align-items:center;justify-content:center}.destination-card.voted .vote-button{background:#28a745}.voting-results{background:white;padding:2rem;border-radius:15px;text-align:center;box-shadow:0 5px 15px #0000001a}.voting-results h4{color:#333;margin-bottom:.5rem;font-size:1.5rem}.voting-results p{color:#6c757d;margin:0}.add-destination-section{margin-top:2rem;text-align:center}.add-destination-btn{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff;border:none;padding:1rem 2rem;border-radius:25px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 5px 15px #28a7454d}.add-destination-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #28a74566}.add-destination-form{background:white;padding:2rem;border-radius:15px;box-shadow:0 5px 15px #0000001a;margin-top:2rem;text-align:left;max-width:600px;margin-left:auto;margin-right:auto;width:100%}.add-destination-form h4{text-align:center;margin-bottom:1.5rem;color:#333;font-size:1.5rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.add-destination-form .form-group{margin-bottom:1.5rem}.add-destination-form .form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#495057}.add-destination-form .form-group input,.add-destination-form .form-group textarea,.add-destination-form .form-group select{width:100%;padding:1rem;border:2px solid #e9ecef;border-radius:10px;font-size:1rem;transition:border-color .3s ease,box-shadow .3s ease;background:white}.add-destination-form .form-group input:focus,.add-destination-form .form-group textarea:focus,.add-destination-form .form-group select:focus{outline:none;border-color:#28a745;box-shadow:0 0 0 3px #28a7451a}.form-help{display:block;margin-top:.5rem;font-size:.85rem;color:#6c757d;font-style:italic}.duplicate-warning{background:#fff3cd;border:1px solid #ffeaa7;color:#856404;padding:.8rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.submit-destination-btn{width:100%;background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff;border:none;padding:1rem 2rem;font-size:1.1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;margin-top:1rem}.submit-destination-btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #28a7454d}.submit-destination-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6;transform:none}.submit-destination-btn:disabled:hover{transform:none;box-shadow:none}.planning-section{margin-bottom:4rem;padding:3rem 0;background:white;border-radius:20px;box-shadow:0 5px 15px #0000001a}.planning-title{text-align:center;font-size:2.5rem;margin-bottom:3rem;color:#333;font-weight:300}.timeline{max-width:800px;margin:0 auto;position:relative}.timeline:before{content:"";position:absolute;left:30px;top:0;bottom:0;width:2px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);z-index:1}.timeline-item{display:flex;align-items:flex-start;margin-bottom:2rem;position:relative;z-index:5}.timeline-marker{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;margin-right:2rem;z-index:10;position:relative}.timeline-item.completed .timeline-marker{background:#28a745}.timeline-item.inactive{filter:grayscale(.3)}.timeline-item.inactive .timeline-marker{background:#6c757d;color:#fff;z-index:10;position:relative}.timeline-item.inactive .timeline-content{background:#f8f9fa;border-left-color:#dee2e6}.timeline-item.inactive .timeline-content h4{color:#6c757d}.timeline-item.inactive .timeline-content p{color:#adb5bd}.timeline-item.inactive .timeline-status{background:#6c757d;color:#fff}.timeline-content{flex:1;background:#f8f9fa;padding:1.5rem;border-radius:10px;border-left:4px solid #667eea}.timeline-content h4{color:#333;margin-bottom:.5rem;font-size:1.2rem}.timeline-content p{color:#6c757d;margin-bottom:.5rem}.timeline-status{background:#667eea;color:#fff;padding:.3rem .8rem;border-radius:15px;font-size:.8rem;font-weight:600}.event-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:4rem}.detail-item{background:#f8f9fa;padding:2rem;border-radius:15px;text-align:center;transition:transform .3s ease,box-shadow .3s ease;border:1px solid #e9ecef}.detail-item:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.detail-item h3{font-size:1.2rem;margin-bottom:1rem;color:#495057}.detail-item p{color:#6c757d;line-height:1.6}.rsvp-form{background:#f8f9fa;padding:3rem;border-radius:20px;max-width:600px;margin:0 auto;box-shadow:0 10px 30px #0000001a}.rsvp-form h3{text-align:center;margin-bottom:2rem;font-size:2rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#495057}.form-group input,.form-group select,.form-group textarea{width:100%;padding:1rem;border:2px solid #e9ecef;border-radius:10px;font-size:1rem;transition:border-color .3s ease,box-shadow .3s ease;background:white}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.rsvp-button{width:100%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:1.2rem 2rem;font-size:1.1rem;font-weight:600;border-radius:10px;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;text-transform:uppercase;letter-spacing:1px}.rsvp-button:hover{transform:translateY(-2px);box-shadow:0 10px 25px #667eea4d}.rsvp-button:active{transform:translateY(0)}.success-message{background:#d4edda;border:1px solid #c3e6cb;color:#155724;padding:2rem;border-radius:15px;text-align:center;max-width:600px;margin:0 auto}.success-message h3{font-size:2rem;margin-bottom:1rem}@media (max-width: 768px){.hero-title{font-size:2.2rem;line-height:1.2;margin-bottom:1rem}.hero-subtitle{font-size:1.1rem;margin-bottom:1.5rem}.countdown-section{padding:1.5rem}.countdown-title{font-size:1.5rem;margin-bottom:1rem}.countdown{flex-wrap:wrap;gap:.6rem;justify-content:center}.countdown-item{min-width:55px;padding:.7rem .5rem;flex:1;max-width:80px}.countdown-number{font-size:1.4rem}.countdown-label{font-size:.65rem}.intro-text{font-size:1rem;line-height:1.5;margin-bottom:1.5rem}.quick-details{gap:.8rem;flex-wrap:wrap;justify-content:center}.quick-detail{padding:.5rem .8rem;font-size:.9rem;flex:1;min-width:120px;text-align:center}.section-title{font-size:1.8rem;margin-bottom:2rem}.destinations-grid{grid-template-columns:1fr;gap:1.5rem;padding:0 .5rem}.destination-card{padding:1.2rem;margin-bottom:.5rem}.destination-header{flex-direction:column;align-items:flex-start;gap:.8rem;margin-bottom:1rem}.destination-image{width:60px;height:60px;align-self:center}.destination-emoji{font-size:1.5rem}.destination-info{text-align:center;width:100%}.destination-info h4{font-size:1.2rem;margin-bottom:.3rem}.vote-count{margin-left:0;align-self:center}.destination-description{font-size:.95rem;line-height:1.5;margin-bottom:1rem}.destination-highlights{gap:.3rem;margin-bottom:1rem;justify-content:center;max-height:45px}.highlight-tag{font-size:.65rem;padding:.2rem .4rem}.vote-button{padding:.7rem 1.2rem;font-size:.95rem}.voting-title,.planning-title{font-size:1.8rem;margin-bottom:1rem}.voting-subtitle{font-size:1rem;margin-bottom:2rem}.form-row{grid-template-columns:1fr;gap:.8rem}.add-destination-form{padding:1.5rem;margin:1.5rem 0}.add-destination-form h4{font-size:1.3rem}.timeline:before{left:15px}.timeline-marker{width:30px;height:30px;font-size:.9rem;margin-right:1rem}.timeline-content{padding:1.2rem}.timeline-content h4{font-size:1.1rem}.timeline-content p{font-size:.9rem}.rsvp-form{padding:1.5rem 1rem}.rsvp-form h3{font-size:1.5rem}.rsvp-button{padding:1rem 1.5rem;font-size:1rem}.container{padding:0 1rem}.voting-section{padding:2rem 1rem}.voting-deadline-small{margin-bottom:1.5rem}.voting-deadline-small .voting-deadline{min-width:200px;padding:.6rem 1rem;font-size:.9rem;background:rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.6)}.voting-deadline-small .deadline-label{font-size:.8rem;font-weight:700;text-shadow:0 2px 6px rgba(0,0,0,.8)}.voting-deadline-small .deadline-countdown{gap:.4rem}.voting-deadline-small .deadline-countdown .countdown-item{min-width:1.5rem;padding:.3rem .25rem;background:rgba(0,0,0,.4);border:2px solid rgba(255,255,255,.5)}.voting-deadline-small .deadline-countdown .countdown-number{font-size:.9rem;font-weight:900;text-shadow:0 3px 6px rgba(0,0,0,.8)}.voting-deadline-small .deadline-countdown .countdown-label{font-size:.55rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.8)}.planning-section{padding:2rem 0}}@media (max-width: 480px){.hero-title{font-size:1.8rem;line-height:1.1}.hero-subtitle{font-size:.95rem;margin-bottom:1.2rem}.countdown-section{padding:1.2rem}.countdown-title{font-size:1.2rem;margin-bottom:.8rem}.countdown{gap:.4rem}.countdown-item{padding:.5rem .3rem;min-width:45px;max-width:65px}.countdown-number{font-size:1.1rem}.countdown-label{font-size:.55rem}.intro-text{font-size:.95rem;line-height:1.4}.quick-details{flex-direction:column;gap:.6rem}.quick-detail{padding:.4rem .6rem;font-size:.85rem;min-width:auto}.section-title{font-size:1.6rem}.destination-card{padding:1rem .8rem}.destination-header{flex-direction:column;align-items:center;gap:.6rem;text-align:center}.destination-image{width:50px;height:50px}.destination-emoji{font-size:1.2rem}.destination-info h4{font-size:1.1rem}.destination-info p{font-size:.85rem}.destination-creator{font-size:.75rem!important}.vote-count{margin-left:0;align-self:center}.vote-number{font-size:1.3rem}.vote-label{font-size:.7rem}.destination-description{font-size:.9rem;line-height:1.4}.destination-highlights{gap:.25rem;flex-wrap:wrap;max-height:40px}.highlight-tag{font-size:.6rem;padding:.15rem .4rem}.vote-button{padding:.6rem 1rem;font-size:.9rem}.voting-title,.planning-title{font-size:1.6rem}.voting-subtitle{font-size:.95rem}.add-destination-form{padding:1.2rem}.add-destination-form h4{font-size:1.2rem}.timeline-content{padding:1rem}.timeline-content h4{font-size:1rem}.timeline-content p{font-size:.85rem}.rsvp-form{padding:1.2rem .8rem}.rsvp-form h3{font-size:1.3rem}.rsvp-button{padding:.9rem 1.2rem;font-size:.95rem}.container{padding:0 .8rem}.voting-section{padding:1.5rem .8rem}.voting-deadline-small{margin-bottom:1.2rem}.voting-deadline-small .voting-deadline{min-width:180px;padding:.5rem .8rem;font-size:.85rem;background:rgba(0,0,0,.6);border:2px solid rgba(255,255,255,.7)}.voting-deadline-small .deadline-label{font-size:.75rem;font-weight:700;text-shadow:0 2px 6px rgba(0,0,0,.8)}.voting-deadline-small .deadline-countdown{gap:.3rem}.voting-deadline-small .deadline-countdown .countdown-item{min-width:1.3rem;padding:.25rem .2rem;background:rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.6)}.voting-deadline-small .deadline-countdown .countdown-number{font-size:.8rem;font-weight:900;text-shadow:0 3px 6px rgba(0,0,0,.8)}.voting-deadline-small .deadline-countdown .countdown-label{font-size:.5rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.8)}.planning-section{padding:1.5rem 0}.modal-content{padding:1.5rem;margin:1rem}.modal-content h3{font-size:1.3rem}.name-input{font-size:16px}.modal-buttons{flex-direction:column;gap:.8rem}.cancel-btn,.confirm-btn{width:100%;padding:1rem}}.destination-card{-webkit-tap-highlight-color:transparent;touch-action:manipulation;position:relative}@media (max-width: 768px){.destination-card{padding-bottom:4rem}.vote-button{position:sticky;bottom:0;z-index:10;box-shadow:0 -2px 10px #0000001a}}.vote-button,.rsvp-button,.add-destination-btn,.submit-destination-btn{-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:48px;min-width:48px}.vote-button:active{transform:scale(.95);transition:transform .1s ease}.vote-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6;transform:none}.vote-button:disabled:hover{transform:none;box-shadow:none}@media (hover: hover){.vote-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}}.voting-deadline{display:flex;align-items:center;gap:1rem;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:18px;padding:1.2rem 1.5rem;border:2px solid rgba(255,255,255,.5);transition:all .3s ease;min-width:280px;box-shadow:0 6px 20px #0000004d}.voting-deadline:hover{transform:translateY(-3px);background:rgba(0,0,0,.5);box-shadow:0 8px 25px #0006}.voting-deadline.expired{background:rgba(220,53,69,.6);border-color:#dc3545cc}.deadline-icon{font-size:1.5rem;flex-shrink:0;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5))}.deadline-content{display:flex;flex-direction:column;gap:.8rem;flex:1}.deadline-label{font-size:.95rem;opacity:1;font-weight:700;color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.8);letter-spacing:.5px}.deadline-countdown{display:flex;gap:.8rem;align-items:center;justify-content:center}.deadline-countdown .countdown-item{display:flex;flex-direction:column;align-items:center;min-width:2.5rem;background:rgba(0,0,0,.3);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:.7rem .5rem;border:2px solid rgba(255,255,255,.4);transition:all .3s ease;box-shadow:0 3px 10px #0000004d}.deadline-countdown .countdown-item:hover{transform:translateY(-3px);background:rgba(0,0,0,.4);box-shadow:0 5px 15px #0006}.deadline-countdown .countdown-number{font-size:1.3rem;font-weight:900;line-height:1;color:#fff;text-shadow:0 3px 6px rgba(0,0,0,.8)}.deadline-countdown .countdown-label{font-size:.7rem;opacity:1;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.8);letter-spacing:.5px;margin-top:.2rem}@media (max-width: 768px){.voting-deadline{min-width:200px;padding:.8rem 1rem;gap:.8rem;background:rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.6)}.deadline-icon{font-size:1.3rem}.deadline-label{font-size:.85rem;font-weight:700;text-shadow:0 2px 6px rgba(0,0,0,.8)}.deadline-countdown{gap:.5rem}.deadline-countdown .countdown-item{min-width:2rem;padding:.5rem .4rem;background:rgba(0,0,0,.4);border:2px solid rgba(255,255,255,.5)}.deadline-countdown .countdown-number{font-size:1.1rem;font-weight:900;text-shadow:0 3px 6px rgba(0,0,0,.8)}.deadline-countdown .countdown-label{font-size:.6rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.8)}}@media (max-width: 480px){.voting-deadline{min-width:180px;padding:.7rem .9rem;gap:.7rem;background:rgba(0,0,0,.6);border:2px solid rgba(255,255,255,.7)}.deadline-icon{font-size:1.2rem}.deadline-label{font-size:.8rem;font-weight:700;text-shadow:0 2px 6px rgba(0,0,0,.8)}.deadline-countdown{gap:.4rem}.deadline-countdown .countdown-item{min-width:1.8rem;padding:.4rem .3rem;background:rgba(0,0,0,.5);border:2px solid rgba(255,255,255,.6)}.deadline-countdown .countdown-number{font-size:1rem;font-weight:900;text-shadow:0 3px 6px rgba(0,0,0,.8)}.deadline-countdown .countdown-label{font-size:.55rem;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.8)}}html{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}input[type=text],input[type=email],textarea,select{font-size:16px}@media (prefers-reduced-motion: no-preference){.countdown-item{animation:pulse 2s ease-in-out infinite}.countdown-item:nth-child(1){animation-delay:0s}.countdown-item:nth-child(2){animation-delay:.2s}.countdown-item:nth-child(3){animation-delay:.4s}.countdown-item:nth-child(4){animation-delay:.6s}}@media (prefers-reduced-motion: reduce){.countdown-item{animation:none}.hero-section:before,.hero-section:after{animation:none}.hero-section,.hero-content{animation:none}*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.name-input-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background:white;padding:2rem;border-radius:15px;box-shadow:0 20px 40px #0000004d;max-width:400px;width:90%;text-align:center;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content h3{color:#333;margin-bottom:1rem;font-size:1.5rem}.modal-content p{color:#6c757d;margin-bottom:1.5rem;line-height:1.5}.name-input{width:100%;padding:1rem;border:2px solid #e9ecef;border-radius:10px;font-size:1rem;margin-bottom:1.5rem;transition:border-color .3s ease}.name-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.modal-buttons{display:flex;gap:1rem;justify-content:center}.cancel-btn,.confirm-btn{padding:.8rem 1.5rem;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;border:none;min-width:100px}.cancel-btn{background:#6c757d;color:#fff}.cancel-btn:hover{background:#5a6268;transform:translateY(-1px)}.confirm-btn{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.confirm-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 5px 15px #667eea4d}.confirm-btn:disabled{background:#e9ecef;color:#6c757d;cursor:not-allowed}.voter-info{color:#28a745;font-size:.9rem;margin-top:.5rem}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid #667eea;outline-offset:2px}.skip-link{position:absolute;top:-40px;left:6px;background:#667eea;color:#fff;padding:8px;text-decoration:none;border-radius:4px;z-index:10000}.skip-link:focus{top:6px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}
