@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300..900;1,9..144,300..900&family=Manrope:wght@400;500;600;700;800&display=swap");:root{--bg:#faf7f2;--ink:#1f1b19;--paper:#fff;--muted:#8a8077;--radius:28px;--shadow:0 18px 40px -18px rgba(0,0,0,.22);--m1:#6b2737;--m2:#2e4057;--m3:#f7d9d0;--accent:#6b2737}*{box-sizing:border-box}body,html{margin:0;padding:0}body,html{overflow-x:hidden}body{background:var(--bg);font-family:Manrope,sans-serif;color:var(--ink);min-height:100vh;max-width:100vw;display:flex;flex-direction:column;align-items:center;padding:48px 20px 80px;transition:background .6s ease}[id^=view]{width:100%;max-width:100%;overflow-x:hidden}.app-head{width:100%;max-width:640px;justify-content:space-between;margin-bottom:28px;flex-wrap:wrap;gap:14px}.app-head,.menu-btn{display:flex;align-items:center}.menu-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:var(--paper);width:42px;height:42px;border-radius:14px;justify-content:center;cursor:pointer;box-shadow:var(--shadow);flex-shrink:0;transition:transform .2s,background .2s}.menu-btn:hover{transform:translateY(-1px)}.menu-btn svg{width:19px;height:19px;color:var(--ink)}.head-left{display:flex;align-items:center;gap:14px}.sidebar-overlay{position:fixed;inset:0;background:rgba(20,16,14,.45);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:90;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.sidebar-overlay.show{opacity:1;visibility:visible}.sidebar{position:fixed;top:0;left:0;height:100%;width:min(270px,82vw);background:var(--paper);z-index:95;box-shadow:18px 0 50px -20px rgba(0,0,0,.35);transform:translateX(-100%);transition:transform .4s cubic-bezier(.2,.85,.25,1);display:flex;flex-direction:column;padding:26px 20px}.sidebar.show{transform:translateX(0)}.sidebar-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px}.sidebar-brand{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:20px;color:var(--ink)}.sidebar-brand em{color:var(--accent)}.sidebar-close{width:34px;height:34px;border-radius:50%;border:none;background:rgba(0,0,0,.06);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:15px;transition:background .2s,transform .2s}.sidebar-close:hover{background:var(--ink);color:#fff;transform:rotate(90deg)}.sidebar-nav{display:flex;flex-direction:column;gap:6px}.sidebar-link{display:flex;align-items:center;gap:13px;padding:13px 14px;border-radius:16px;cursor:pointer;font-weight:700;font-size:14.5px;color:var(--ink);text-decoration:none;transition:background .2s,color .2s,transform .15s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sidebar-link:hover{background:#f1ece4;transform:translateX(2px)}.sidebar-link.active{background:var(--accent);color:#fff}.sidebar-link .link-icon{width:34px;height:34px;border-radius:50%;background:rgba(0,0,0,.05);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.sidebar-link.active .link-icon{background:hsla(0,0%,100%,.2)}.sidebar-link .link-icon svg{width:16px;height:16px}.sidebar-foot{margin-top:auto;padding-top:20px;border-top:1px solid rgba(0,0,0,.06);font-family:Fraunces,serif;font-style:italic;font-size:17px;letter-spacing:.02em;color:var(--ink);text-align:center}.timeline-wrap{width:100%;max-width:640px;margin:18px auto 0;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px 32px 26px}.timeline-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px;flex-wrap:wrap;gap:10px}.timeline-today{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.timeline-today b{display:block;font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:18px;letter-spacing:0;text-transform:none;color:var(--ink);margin-top:3px}.timeline-countdown{text-align:right}.timeline-countdown .num{font-family:Fraunces,serif;font-weight:700;font-size:38px;line-height:1;color:#d4af37}.timeline-countdown .lbl{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:2px}.timeline-track-wrap{position:relative;padding-top:46px;padding-bottom:8px}.timeline-track{position:relative;height:6px;border-radius:6px;background:#efe9de;overflow:visible}.timeline-track-fill{position:absolute;top:0;left:0;height:100%;border-radius:6px;background:linear-gradient(90deg,#d4af37,#f4e2a1);transition:width 1s ease}.timeline-end,.timeline-start{position:absolute;top:50%;transform:translate(-50%,-50%);width:13px;height:13px;border-radius:50%;background:var(--paper);border:2.5px solid #d9d2c7;z-index:2}.timeline-start{left:0}.timeline-end{left:100%;border-color:#d4af37;background:#d4af37}.timeline-end svg{position:absolute;top:-30px;left:50%;transform:translateX(-50%);width:18px;height:18px;color:#d4af37}.timeline-labels{display:flex;justify-content:space-between;margin-top:10px;font-size:10.5px;font-weight:700;color:var(--muted);letter-spacing:.03em}.couple-walker{top:-46px;width:54px;height:54px;transition:left 1.2s cubic-bezier(.3,.8,.3,1);z-index:3}.couple-walker,.couple-walker .bubble{position:absolute;transform:translateX(-50%)}.couple-walker .bubble{bottom:50px;left:50%;background:var(--ink);color:#fff;font-size:10px;font-weight:700;padding:4px 9px;border-radius:10px;white-space:nowrap;opacity:0;transition:opacity .25s;pointer-events:none}.couple-walker:hover .bubble{opacity:1}.couple-walker svg{width:100%;height:100%;animation:coupleBob 1.1s ease-in-out infinite}.couple-walker .leg{transform-origin:top center;animation:legSwing .55s ease-in-out infinite alternate}.couple-walker .leg2{animation-delay:.275s}.couple-walker .leg3{animation-delay:.07s}.couple-walker .leg4{animation-delay:.345s}@keyframes coupleBob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes legSwing{0%{transform:rotate(-16deg)}to{transform:rotate(16deg)}}.timeline-footnote{text-align:center;font-size:12px;color:var(--muted);margin-top:34px;font-weight:600}.timeline-footnote b{color:var(--ink)}@media (max-width:520px){.timeline-wrap{padding:26px 20px 22px}.timeline-countdown .num{font-size:30px}}.info-section{max-width:640px;margin:0 auto;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:36px 32px 34px}.info-intro{text-align:center;margin-bottom:26px}.info-intro h2{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:30px;margin:0 0 6px}.info-intro p{font-size:13.5px;color:var(--muted);margin:0 auto;max-width:380px}.info-cards{display:flex;flex-direction:column;gap:14px}.info-card{border:1.5px solid rgba(0,0,0,.07);border-radius:20px;padding:22px 22px 20px}.info-card-head{gap:13px;margin-bottom:14px}.info-card-head,.info-icon{display:flex;align-items:center}.info-icon{width:42px;height:42px;border-radius:50%;justify-content:center;flex-shrink:0;color:#fff}.info-icon svg{width:19px;height:19px}.info-card-title{font-family:Fraunces,serif;font-weight:700;font-size:17px;color:var(--ink)}.info-row{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:#4a433d;line-height:1.55;margin-bottom:8px}.info-row:last-child{margin-bottom:0}.info-row .info-label{font-weight:800;color:var(--ink);min-width:64px;flex-shrink:0}.info-warning{margin-top:14px;background:#fcefe3;border-radius:14px;padding:13px 16px;font-size:12.5px;color:#8a5a24;line-height:1.55;display:flex;gap:10px;align-items:flex-start}.info-warning svg{width:17px;height:17px;flex-shrink:0;margin-top:1px;color:#c77b2c}.info-warning b{color:#6e4316}.dress-highlight{margin-top:14px;background:linear-gradient(135deg,#fbf8f4,#f4efe6);border:1.5px solid #e8dfd0;border-radius:16px;padding:20px 18px;text-align:center}.dress-highlight .big{font-family:Fraunces,serif;font-style:italic;font-weight:700;font-size:21px;color:var(--ink);line-height:1.3}.dress-highlight .big em{font-style:italic;color:#c8334a;border-bottom:2px solid #f3c9d1}.dress-highlight .small{font-size:12px;color:var(--muted);margin-top:8px;font-weight:600}.adults-banner{margin-top:4px;background:linear-gradient(135deg,#2e4057,#1f2c3d);border-radius:16px;padding:20px;color:#fff}.adults-banner p{font-size:13.5px;line-height:1.6;margin:0 0 12px}.adults-banner .note{display:flex;gap:9px;align-items:flex-start;font-size:12px;background:hsla(0,0%,100%,.1);border-radius:12px;padding:11px 13px;line-height:1.5}.adults-banner .note svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}.stay-list{display:flex;flex-direction:column;gap:10px}.stay-item{border:1.5px solid rgba(0,0,0,.06);border-radius:14px;padding:13px 15px}.stay-name{font-weight:700;font-size:13.5px;color:var(--ink);display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:3px}.stay-name .stay-tag{font-size:10px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--gift-gold);white-space:nowrap}.stay-desc{font-size:12px;color:var(--muted);line-height:1.5}.stay-link{display:inline-flex;align-items:center;gap:4px;margin-top:8px;font-size:11px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:var(--gift-gold);text-decoration:none;transition:color .2s}.stay-link:hover{color:var(--accent)}.stay-link svg{width:11px;height:11px}.std-section{max-width:640px;margin:0 auto;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:36px 32px 34px}.std-intro{text-align:center;margin-bottom:26px}.std-intro h2{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:30px;margin:0 0 6px}.std-intro p{font-size:13.5px;color:var(--muted);margin:0 auto;max-width:380px}.std-player{position:relative;width:100%;max-width:360px;margin:0 auto;aspect-ratio:9/16;border-radius:20px;overflow:hidden;background:linear-gradient(135deg,#6b2737,#2e4057);box-shadow:0 20px 40px -18px rgba(0,0,0,.35)}.std-player video{width:100%;height:100%;object-fit:cover;display:block;background:#000}.std-placeholder{position:absolute;inset:0;flex-direction:column;gap:14px;color:#fff;text-align:center;padding:30px}.std-placeholder,.std-placeholder .std-icon{display:flex;align-items:center;justify-content:center}.std-placeholder .std-icon{width:64px;height:64px;border-radius:50%;background:hsla(0,0%,100%,.18);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);cursor:pointer;transition:transform .2s,background .2s}.std-placeholder .std-icon:hover{transform:scale(1.07);background:hsla(0,0%,100%,.28)}.std-placeholder .std-icon svg{width:26px;height:26px;margin-left:3px}.std-placeholder h3{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:21px;margin:0}.std-placeholder p{font-size:12px;opacity:.85;max-width:280px;margin:0;line-height:1.5}.std-hearts-deco{position:absolute;top:16px;right:18px;font-size:18px;opacity:.55}.std-caption{display:flex;justify-content:space-between;align-items:baseline;margin-top:18px;flex-wrap:wrap;gap:8px}.std-caption .date{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:16px;color:var(--ink)}.std-caption .tag{font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gift-gold)}.std-note{text-align:center;font-size:12.5px;color:var(--muted);margin-top:24px;line-height:1.6}.std-note b{color:var(--ink)}.survey-section{max-width:640px;margin:0 auto;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:32px}.survey-intro{text-align:center;margin-bottom:22px}.survey-intro h2{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:30px;margin:0 0 6px}.survey-intro p{font-size:13.5px;color:var(--muted);margin:0 auto;max-width:380px}.survey-tabs{display:flex;gap:8px;background:#f4efe6;border-radius:16px;padding:5px;margin-bottom:26px}.survey-tab{flex:1 1;border:none;background:transparent;padding:11px 10px;border-radius:12px;font-family:Manrope;font-weight:700;font-size:13px;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:background .25s,color .25s}.survey-tab svg{width:15px;height:15px}.survey-tab.active{background:var(--paper);color:var(--ink);box-shadow:0 4px 12px -4px rgba(0,0,0,.18)}.survey-panel{display:none}.survey-panel.active{display:block;animation:panelFade .3s ease}@keyframes panelFade{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.field-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.field-row{display:flex;gap:8px;margin-bottom:22px}.field-row input[type=text]{flex:1 1;font-family:Manrope;font-size:14px;border:1.5px solid rgba(0,0,0,.1);border-radius:14px;padding:13px 16px;outline:none;color:var(--ink);transition:border-color .2s}.field-row input[type=text]:focus{border-color:var(--accent)}.field-row button{border:none;background:var(--accent);color:#fff;font-weight:700;font-size:13px;padding:0 20px;border-radius:14px;cursor:pointer;white-space:nowrap;transition:opacity .2s,transform .15s}.field-row button:hover{opacity:.9;transform:translateY(-1px)}.song-list{display:flex;flex-direction:column;gap:9px}.song-item{gap:12px;border:1.5px solid rgba(0,0,0,.06);border-radius:14px;padding:12px 14px}.song-icon,.song-item{display:flex;align-items:center}.song-icon{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--m1),var(--m2));justify-content:center;flex-shrink:0;color:#fff}.song-icon svg{width:15px;height:15px}.song-text{flex:1 1;min-width:0}.song-name{font-weight:700;font-size:13.5px;color:var(--ink)}.song-by{font-size:11px;color:var(--muted)}.song-like{display:flex;align-items:center;gap:5px;border:none;background:#f1ece4;border-radius:20px;padding:7px 12px;cursor:pointer;font-weight:700;font-size:12px;color:var(--ink);transition:background .2s,color .2s,transform .15s;flex-shrink:0}.song-like:hover{transform:scale(1.05)}.song-like.liked{background:#fce4e4;color:#c8334a}.song-like svg{width:13px;height:13px}.allergy-form .field-label{margin-top:18px}.allergy-form .field-label:first-child{margin-top:0}.text-input{width:100%;font-family:Manrope;font-size:14px;border:1.5px solid rgba(0,0,0,.1);border-radius:14px;padding:13px 16px;outline:none;color:var(--ink);transition:border-color .2s;box-sizing:border-box}.text-input:focus{border-color:var(--accent)}textarea.text-input{resize:vertical;min-height:70px;font-family:Manrope}.chip-options{display:flex;flex-wrap:wrap;gap:8px}.chip-option{border:1.5px solid rgba(0,0,0,.1);border-radius:20px;padding:9px 15px;font-size:12.5px;font-weight:700;color:var(--ink);cursor:pointer;transition:background .2s,border-color .2s,color .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.chip-option:hover{border-color:rgba(0,0,0,.25)}.chip-option.selected{background:var(--accent);border-color:var(--accent);color:#fff}.allergy-submit{width:100%;border:none;background:var(--accent);color:#fff;font-weight:700;font-size:14px;padding:14px;border-radius:16px;cursor:pointer;margin-top:24px;transition:opacity .2s,transform .15s}.allergy-submit:hover{opacity:.92;transform:translateY(-1px)}.allergy-list-wrap{margin-top:28px}.allergy-item{border:1.5px solid rgba(0,0,0,.06);border-radius:14px;padding:13px 16px;margin-bottom:9px}.allergy-item-name{font-weight:700;font-size:13.5px;color:var(--ink);margin-bottom:5px}.allergy-item-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:5px}.allergy-item-tags span{font-size:10.5px;font-weight:700;background:#f1ece4;color:var(--ink);padding:4px 9px;border-radius:10px}.allergy-item-note{font-size:12px;color:var(--muted)}.survey-empty{text-align:center;font-size:12.5px;color:var(--muted);padding:18px 0 4px}.team-section{max-width:640px;margin:0 auto;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:38px 32px 32px}.team-intro{text-align:center;margin-bottom:28px}.team-intro h2{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:30px;margin:0 0 6px}.team-intro p{font-size:13.5px;color:var(--muted);margin:0 auto;max-width:380px}.team-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:14px;gap:14px}@media (max-width:480px){.team-grid{grid-template-columns:1fr}}.team-card{border:1.5px solid rgba(0,0,0,.07);border-radius:18px;padding:18px;display:flex;gap:13px;align-items:flex-start;transition:border-color .2s,transform .15s,box-shadow .2s}.team-card:hover{border-color:rgba(0,0,0,.14);transform:translateY(-2px);box-shadow:0 14px 28px -16px rgba(0,0,0,.22)}.team-avatar{width:50px;height:50px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-family:Fraunces,serif;font-weight:700;font-size:17px}.team-avatar svg{width:22px;height:22px}.team-body{flex:1 1;min-width:0}.team-role{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gift-gold);margin-bottom:3px}.team-name{font-family:Fraunces,serif;font-weight:700;font-size:16px;color:var(--ink);margin-bottom:5px;line-height:1.2}.team-desc{font-size:12px;color:var(--muted);line-height:1.45;margin-bottom:9px}.team-contact{display:flex;gap:8px}.team-contact a{width:28px;height:28px;border-radius:50%;background:#f1ece4;display:flex;align-items:center;justify-content:center;color:var(--ink);text-decoration:none;transition:background .2s,color .2s,transform .15s}.team-contact a:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.team-contact a svg{width:13px;height:13px}.team-thanks{text-align:center;font-size:12.5px;color:var(--muted);margin-top:28px;font-weight:600}.team-thanks b{color:var(--ink)}:root{--gift-gold:#b3873e;--gift-gold-soft:#f7efe0}.gift-section{max-width:640px;margin:0 auto;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:38px 32px 32px}.gift-intro{text-align:center;margin-bottom:28px}.gift-intro h2{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:30px;margin:0 0 6px}.gift-intro p{font-size:13.5px;color:var(--muted);max-width:380px;margin:0 auto}.gift-label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 12px}.amount-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-bottom:30px}.amount-card{border:1.5px solid rgba(0,0,0,.08);border-radius:16px;padding:16px 8px;text-align:center;cursor:pointer;background:var(--paper);transition:border-color .2s,background .2s,transform .15s}.amount-card:hover{transform:translateY(-2px)}.amount-card.selected{border-color:var(--gift-gold);background:var(--gift-gold-soft)}.amount-card .amt{font-family:Fraunces,serif;font-weight:700;font-size:17px;color:var(--ink)}.amount-card .amt-sub{font-size:10.5px;color:var(--muted);font-weight:600;margin-top:2px}.amount-card.selected .amt,.amount-card.selected .amt-sub{color:var(--gift-gold)}.custom-amount-wrap{display:none;margin:-16px 0 26px}.custom-amount-wrap.show{display:block}.custom-amount-wrap input{width:100%;font-family:Fraunces,serif;font-size:18px;font-weight:700;border:1.5px solid var(--gift-gold);border-radius:14px;padding:13px 16px;outline:none;color:var(--ink);background:var(--gift-gold-soft)}.custom-amount-wrap input::placeholder{color:var(--muted);font-weight:500}.dreams-label-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.dreams-label-row .opt{font-size:11px;color:var(--muted);font-weight:600;text-transform:none;letter-spacing:0}.dreams-list{display:flex;flex-direction:column;gap:10px;margin-bottom:26px}.dream-card{border:1.5px solid rgba(0,0,0,.07);border-radius:16px;padding:16px 18px;cursor:pointer;transition:border-color .2s,background .2s;display:flex;gap:14px;align-items:flex-start}.dream-card:hover{border-color:rgba(0,0,0,.16)}.dream-card.selected{border-color:var(--gift-gold);background:var(--gift-gold-soft)}.dream-check{width:21px;height:21px;border-radius:7px;border:1.8px solid #d8d0c3;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s;background:#fff}.dream-check svg{width:12px;height:12px;color:#fff;opacity:0;transition:opacity .15s}.dream-card.selected .dream-check{background:var(--gift-gold);border-color:var(--gift-gold)}.dream-card.selected .dream-check svg{opacity:1}.dream-body{flex:1 1;min-width:0}.dream-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:8px}.dream-name{font-family:Fraunces,serif;font-weight:700;font-size:15.5px;color:var(--ink)}.dream-pct{font-size:12px;font-weight:700;color:var(--gift-gold);flex-shrink:0}.dream-bar-track{height:7px;border-radius:6px;background:#efe9de;overflow:hidden;margin-bottom:7px}.dream-bar-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--gift-gold),#d8b873);transition:width .5s ease}.dream-figures{font-size:11.5px;color:var(--muted);font-weight:600}.gift-summary{background:var(--gift-gold-soft);border-radius:18px;padding:16px 18px;margin-bottom:18px;font-size:13px;color:#6b5530;display:none}.gift-summary.show{display:block}.gift-summary b{color:var(--ink)}.gift-continue{width:100%;border:none;background:var(--gift-gold);color:#fff;font-weight:700;font-size:15px;padding:17px;border-radius:18px;cursor:pointer;transition:opacity .2s,transform .15s;font-family:Manrope}.gift-continue:hover{opacity:.92;transform:translateY(-1px)}.gift-continue:disabled{opacity:.45;cursor:not-allowed;transform:none}.section-soon{max-width:640px;margin:0 auto;background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:60px 36px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}.section-soon .soon-icon{width:54px;height:54px;border-radius:50%;background:linear-gradient(135deg,var(--m1),var(--m2));display:flex;align-items:center;justify-content:center}.section-soon .soon-icon svg{width:24px;height:24px;color:#fff}.section-soon h2{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:26px;margin:0}.section-soon p{font-size:13.5px;color:var(--muted);max-width:300px;margin:0}.brand{display:flex;flex-direction:column;gap:2px;font-family:Fraunces,serif;font-weight:600;font-size:14px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.brand b{color:var(--ink)}.brand-names{font-family:Fraunces,serif;font-size:clamp(34px,6vw,52px);line-height:.95;font-style:italic;font-weight:700;letter-spacing:.005em;text-transform:none;color:var(--accent)}.brand-tagline{font-family:Fraunces,serif;font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.year-title{font-family:Fraunces,serif;font-weight:300;font-size:clamp(34px,6vw,52px);line-height:.95;margin:0}.year-title em{font-style:italic;font-weight:600;color:var(--accent);transition:color .5s}.layout{margin:0 auto}.layout,.milestones-wrap{width:100%;max-width:640px}.milestones-wrap{margin:0 auto 18px;padding:0 6px}.milestones-label{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.milestones-row{position:relative;display:flex;align-items:center;gap:6px}.milestones{display:flex;gap:10px;overflow-x:auto;overscroll-behavior-x:contain;padding:2px 10px 6px 2px;scrollbar-width:none;scroll-behavior:smooth;flex:1 1;min-width:0}.milestones::-webkit-scrollbar{display:none}.cupid-arrow{flex-shrink:0;width:32px;height:32px;border-radius:50%;border:none;background:var(--paper);box-shadow:0 6px 14px -6px rgba(0,0,0,.25);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--accent);transition:transform .2s,background .2s,color .2s,opacity .2s;opacity:0;visibility:hidden;pointer-events:none}.cupid-arrow.visible{opacity:1;visibility:visible;pointer-events:auto}.cupid-arrow:hover{background:var(--accent);color:#fff;transform:scale(1.1) rotate(-6deg)}.cupid-arrow.next:hover{transform:scale(1.1) rotate(6deg)}.cupid-arrow svg{width:17px;height:17px}.cupid-arrow.prev svg{transform:scaleX(-1)}.milestone-chip{flex-shrink:0;display:flex;align-items:center;gap:9px;background:var(--paper);border:1px solid rgba(0,0,0,.06);border-radius:18px;padding:9px 14px 9px 10px;cursor:pointer;box-shadow:0 6px 16px -8px rgba(0,0,0,.18);transition:transform .18s,box-shadow .18s,border-color .2s;animation:chipIn .35s cubic-bezier(.2,.8,.2,1) backwards}.milestone-chip:hover{transform:translateY(-2px);box-shadow:0 10px 22px -8px rgba(0,0,0,.26)}.milestone-chip .chip-icon{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--m1),var(--m2));display:flex;align-items:center;justify-content:center;flex-shrink:0}.milestone-chip .chip-icon svg{width:15px;height:15px;color:#fff}.milestone-chip.wedding .chip-icon{background:linear-gradient(135deg,#d4af37,#f4e2a1)}.milestone-chip .chip-text{display:flex;flex-direction:column;line-height:1.25;max-width:190px;min-width:0}.milestone-chip .chip-day{font-family:Fraunces,serif;font-size:14.5px;color:var(--ink)}.milestone-chip .chip-day,.milestone-chip .chip-title{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.milestone-chip .chip-title{font-size:10.5px;color:var(--muted)}.milestone-chip.wedding{border-color:#d4af37;background:#fffbf0}.milestones-empty{font-size:13px;color:var(--muted);padding:10px 2px}@keyframes chipIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.card{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;position:relative}.nav-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:rgba(0,0,0,.055);width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink);transition:background .25s,transform .2s,color .25s;flex-shrink:0}.nav-btn:hover{background:var(--accent);color:#fff;transform:scale(1.08)}.nav-btn:active{transform:scale(.92)}.nav-btn:disabled{opacity:.35;cursor:not-allowed}.nav-btn:disabled:hover{background:rgba(0,0,0,.055);color:var(--ink);transform:none}.nav-btn svg{width:16px;height:16px}.card-top{background:linear-gradient(180deg,var(--m3) 0,var(--paper) 92%);padding:42px 40px 6px;display:flex;flex-direction:column;align-items:center;position:relative;transition:background .6s ease}.photo-heart{width:220px;height:198px;position:relative;margin-bottom:8px;filter:drop-shadow(0 14px 24px rgba(0,0,0,.18))}.photo-heart .ph-fill{position:absolute;inset:0;-webkit-clip-path:url(#heartClip);clip-path:url(#heartClip);display:flex;align-items:center;justify-content:center;color:#fff;font-family:Manrope;font-size:12px;text-align:center;padding:30px;transition:background 1.2s ease}.month-nav{gap:16px;margin:2px 0 0}.month-label-wrap,.month-nav{display:flex;align-items:center}.month-label-wrap{position:relative;min-width:190px;height:48px;justify-content:center}.month-label{font-family:Fraunces,serif;font-style:italic;font-weight:500;font-size:36px;color:var(--ink);white-space:nowrap}.month-label-year{font-family:Manrope,sans-serif;font-style:normal;font-weight:700;font-size:14px;letter-spacing:.02em;color:var(--accent);vertical-align:middle;margin-left:6px}.month-sub-wrap{height:16px;overflow:hidden;position:relative;min-width:230px;margin-bottom:16px;display:flex;align-items:center;justify-content:center}.month-sub{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;white-space:nowrap}.dots{display:flex;gap:6px;justify-content:center;margin-bottom:14px}.dots span{width:6px;height:6px;border-radius:50%;background:#e3dcd2;transition:background .3s,transform .3s;cursor:pointer}.dots span.on{background:var(--accent);transform:scale(1.35)}@keyframes slideOutToLeft{to{transform:translateX(-26px);opacity:0}}@keyframes slideInFromRight{0%{transform:translateX(26px);opacity:0}to{transform:translateX(0);opacity:1}}@keyframes slideOutToRight{to{transform:translateX(26px);opacity:0}}@keyframes slideInFromLeft{0%{transform:translateX(-26px);opacity:0}to{transform:translateX(0);opacity:1}}.out-left{animation:slideOutToLeft .22s ease forwards}.in-right{animation:slideInFromRight .32s cubic-bezier(.2,.7,.3,1) forwards}.out-right{animation:slideOutToRight .22s ease forwards}.in-left{animation:slideInFromLeft .32s cubic-bezier(.2,.7,.3,1) forwards}.photo-heart.out-left,.photo-heart.out-right{animation-duration:.24s}.photo-heart.in-left,.photo-heart.in-right{animation-duration:.36s}.grid-wrap{padding:6px 40px 36px;overflow:hidden}.dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px}.dow span{text-align:center;font-size:11px;font-weight:800;letter-spacing:.08em;color:var(--muted);padding:6px 0}.days{display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:54px;grid-gap:4px;gap:4px}.day{position:relative;display:flex;align-items:center;justify-content:center;border-radius:14px;cursor:pointer;font-family:Fraunces,serif;font-size:16px;font-weight:500;color:var(--ink);background:transparent;transition:background .2s,transform .12s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.day:hover{background:#f1ece4;transform:scale(1.05)}.day.empty{cursor:default}.day.empty:hover{background:transparent;transform:none}.day.today{outline:2px solid var(--accent);outline-offset:-2px;font-weight:800}.day .heart-mark{position:absolute;top:2px;right:4px;font-size:12px;color:#e0294b;filter:drop-shadow(0 1px 1px rgba(0,0,0,.15))}.day.wedding{font-weight:800}.day.wedding:after{content:"";position:absolute;inset:5px;border-radius:12px;background:linear-gradient(135deg,#d4af37,#f4e2a1);opacity:.35;z-index:0}.day.wedding.selected:after{opacity:0}.day .ring-mark{position:absolute;top:1px;right:3px;width:15px;height:15px;z-index:1}.day.selected .ring-mark{filter:brightness(0) invert(1)}.day.has-content{font-weight:800}.day.has-content:after{content:"";position:absolute;inset:5px;border-radius:12px;background:var(--m1);opacity:.16;z-index:0;transition:background .6s ease}.day.has-content span.num{position:relative;z-index:1}.day.selected{background:var(--accent)!important;color:#fff}.day.selected .heart-mark{color:#fff}.day.selected:after{opacity:0}.legend{display:flex;gap:16px;align-items:center;padding:0 40px 28px;font-size:12px;color:var(--muted);font-weight:600;flex-wrap:wrap}.legend .dot{display:inline-flex;align-items:center;gap:6px}.legend .heart-sample{color:#e0294b;font-size:13px}.legend .sq{width:13px;height:13px;border-radius:4px;background:var(--m1);opacity:.4;display:inline-block;transition:background .6s ease}.swipe-track{touch-action:pan-y}.modal-overlay{position:fixed;inset:0;background:rgba(20,16,14,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:24px;z-index:100;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease}.modal-overlay.show{opacity:1;visibility:visible}.modal{background:var(--paper);border-radius:26px;max-width:460px;width:100%;max-height:88vh;overflow-y:auto;box-shadow:0 30px 70px -20px rgba(0,0,0,.45);transform:scale(.92) translateY(18px);transition:transform .35s cubic-bezier(.2,.8,.2,1);position:relative}.modal-overlay.show .modal{transform:scale(1) translateY(0)}.modal-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:none;background:rgba(0,0,0,.08);color:var(--ink);font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:5;transition:background .2s,color .2s,transform .2s}.modal-close:hover{background:var(--ink);color:#fff;transform:rotate(90deg)}.modal-media{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,var(--m1),var(--m2));display:flex;align-items:center;justify-content:center;position:relative;color:#fff;font-family:Manrope;overflow:hidden}.modal-media .ph-icon{width:54px;height:54px;opacity:.9}.modal-media .media-tag{position:absolute;top:14px;left:14px;background:hsla(0,0%,100%,.92);color:var(--ink);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:20px;display:flex;align-items:center;gap:6px}.modal-media .media-tag svg{width:13px;height:13px}.modal-body{padding:26px 28px 30px}.modal-eyebrow{font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:800;color:var(--accent);margin-bottom:6px;display:flex;align-items:center;gap:6px}.modal-date{font-family:Fraunces,serif;font-style:italic;font-weight:600;font-size:30px;margin:0 0 12px;color:var(--ink);line-height:1.05}.modal-desc{font-size:14.5px;line-height:1.6;color:#4a433d;margin-bottom:18px}.modal-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:10px 4px 4px}.modal-empty svg{width:34px;height:34px;color:var(--muted)}.modal-empty p{font-size:13.5px;color:var(--muted);margin:0;max-width:280px}.modal-add-btn{margin-top:6px;border:none;background:var(--accent);color:#fff;font-weight:700;font-size:13px;padding:11px 22px;border-radius:30px;cursor:pointer;transition:transform .15s,opacity .2s}.modal-add-btn:hover{transform:translateY(-1px);opacity:.92}.modal-gallery{display:flex;gap:8px;margin-top:4px}.modal-gallery .thumb{flex:1 1;aspect-ratio:1;border-radius:12px;background:linear-gradient(135deg,var(--m2),var(--m3));display:flex;align-items:center;justify-content:center;color:var(--ink);opacity:.85}.modal-gallery .thumb svg{width:18px;height:18px;opacity:.6}.panel{position:fixed;bottom:24px;right:24px;max-width:290px;background:var(--ink);color:#fff;border-radius:20px;padding:18px 20px;box-shadow:0 20px 50px -10px rgba(0,0,0,.4);font-size:13.5px;line-height:1.5;transform:translateY(140%);opacity:0;transition:transform .35s cubic-bezier(.2,.8,.2,1),opacity .35s;z-index:50}.panel.show{transform:translateY(0);opacity:1}.panel .ptitle{font-family:Fraunces,serif;font-style:italic;font-size:18px;margin-bottom:4px;display:flex;align-items:center;gap:8px}.panel button.close{background:hsla(0,0%,100%,.12);border:none;color:#fff;border-radius:8px;font-size:11px;padding:6px 10px;margin-top:10px;cursor:pointer;font-weight:700}@media (max-width:600px){body{padding:26px 14px 60px}.app-head{flex-wrap:nowrap;gap:10px}.head-left{flex:1 1 auto;gap:10px}.brand,.head-left{min-width:0}.brand-names{font-size:clamp(22px,7vw,30px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.brand-tagline{font-size:9.5px;letter-spacing:.08em}.year-title{flex-shrink:0;font-size:clamp(26px,9vw,38px)}.menu-btn{width:38px;height:38px;flex-shrink:0}.card-top{padding:22px 10px 6px}.photo-heart{width:130px;height:117px}.month-nav{gap:6px}.nav-btn{width:30px;height:30px}.nav-btn svg{width:13px;height:13px}.month-label-wrap{min-width:0;height:auto}.month-label{font-size:22px}.month-label-year{font-size:10.5px;margin-left:3px}.month-sub-wrap{min-width:0}.month-sub{font-size:9.5px;letter-spacing:.1em}.grid-wrap{padding:6px 4px 18px}.days{grid-auto-rows:34px;gap:2px}.day{font-size:12px;border-radius:9px}.dow span{font-size:8.5px;padding:3px 0}.legend{padding:0 10px 16px;gap:6px 10px;font-size:10px}.milestone-chip{padding:7px 10px 7px 8px;gap:7px}.milestone-chip .chip-icon{width:24px;height:24px}.milestone-chip .chip-icon svg{width:12px;height:12px}.milestone-chip .chip-day{font-size:12.5px}.milestone-chip .chip-title{font-size:9px}.milestone-chip .chip-text{max-width:120px}.modal-overlay{padding:14px}.modal-body{padding:20px 18px 24px}.modal-date{font-size:24px}.timeline-wrap{padding:22px 16px 20px}.timeline-head{flex-direction:column;align-items:flex-start;gap:14px}.timeline-countdown{text-align:left}.timeline-today b{font-size:16px}.timeline-countdown .num{font-size:32px}.gift-section,.info-section,.section-soon,.std-section,.survey-section,.team-section{padding:26px 16px}.gift-intro h2,.info-intro h2,.std-intro h2,.survey-intro h2,.team-intro h2{font-size:24px}.amount-grid{grid-template-columns:repeat(2,1fr)}}.admin-wrap{width:100%;max-width:900px;margin:0 auto}.admin-section{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;margin-bottom:24px}.admin-section h3{font-family:Fraunces,serif;font-style:italic;margin:0 0 16px}.admin-field{margin-bottom:14px;display:flex;flex-direction:column;gap:6px}.admin-field label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.admin-field input,.admin-field select,.admin-field textarea{border:1.5px solid rgba(0,0,0,.1);border-radius:12px;padding:10px 12px;font-family:inherit;font-size:14px}.admin-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:var(--accent);color:#fff;padding:12px 20px;border-radius:14px;font-weight:700;cursor:pointer}.admin-btn:hover{filter:brightness(1.08)}.admin-btn.secondary{background:rgba(0,0,0,.08);color:var(--ink)}.admin-table{width:100%;border-collapse:collapse;font-size:13.5px}.admin-table td,.admin-table th{text-align:left;padding:8px 10px;border-bottom:1px solid rgba(0,0,0,.06)}.admin-login-wrap{min-height:60vh;display:flex;align-items:center;justify-content:center}.admin-login-card{background:var(--paper);border-radius:var(--radius);box-shadow:var(--shadow);padding:36px;width:100%;max-width:360px}.admin-error{color:#b3261e;font-size:13px;margin-top:6px}.badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:11px;font-weight:700}.badge.approved{background:#dcf5e3;color:#1b7a3d}.badge.pending{background:#fdf1d6;color:#9a6a00}.badge.rejected{background:#fbe0de;color:#b3261e}.song-add-row{display:flex;gap:10px;margin-bottom:18px}.song-add-row input{flex:1 1;border:1.5px solid rgba(0,0,0,.12);border-radius:14px;padding:12px 14px;font-family:inherit;font-size:14px}.song-add-row button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:var(--accent);color:#fff;padding:0 20px;border-radius:14px;font-weight:700;cursor:pointer;white-space:nowrap}.song-add-row button:hover{filter:brightness(1.08)}