*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html,body{width:100%;height:100%;overflow:hidden;background:#f5f0e8;-webkit-tap-highlight-color:transparent;}

/* ── STAGE ── */
#stage{
  position:fixed;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,#faf6ec,#f5f0e8,#ede5d0);
  transition:opacity 0.8s ease;
  z-index:10;overflow:hidden;
}
#stage::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(0deg,transparent,transparent 36px,rgba(180,150,80,0.05) 36px,rgba(180,150,80,0.05) 37px);
}
.sf{position:absolute;inset:16px;border:1px solid rgba(200,168,75,0.3);pointer-events:none;}
.sf2{position:absolute;inset:24px;border:0.5px solid rgba(200,168,75,0.15);pointer-events:none;}
.sc{position:absolute;font-size:18px;color:rgba(180,140,50,0.4);line-height:1;}
.sc.tl{top:28px;left:34px}
.sc.tr{top:28px;right:34px}
.sc.bl{bottom:28px;left:34px}
.sc.br{bottom:28px;right:34px}

.seal-wrap{
  position:relative;
  display:flex;align-items:center;justify-content:center;
}
@keyframes sealAppear{
  from{transform:scale(0.7) translateY(20px);opacity:0;}
  to{transform:scale(1) translateY(0);opacity:1;}
}

.ring{position:absolute;border-radius:50%;pointer-events:none;animation:ripple 2.2s ease-out infinite;}
.r1{inset:-12px;border:1.5px solid rgba(139,26,26,0.4);}
.r2{inset:-26px;border:1px solid rgba(139,26,26,0.2);animation-delay:0.45s;}
.r3{inset:-42px;border:0.5px solid rgba(139,26,26,0.1);animation-delay:0.9s;}
@keyframes ripple{0%{transform:scale(0.97);opacity:0.7}100%{transform:scale(1.05);opacity:0}}

.seal-img{
  width:240px;height:240px;
  object-fit:cover;display:block;
  mix-blend-mode:multiply;
  animation:sealAppear 1s cubic-bezier(0.34,1.2,0.64,1) 0.2s both;
}

.countdown{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.countdown-text{
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:3px;
  color:rgba(139,26,26,0.5);white-space:nowrap;
  animation:blink 1s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:0.3}50%{opacity:1}}
.progress-bar-wrap{width:120px;height:2px;background:rgba(139,26,26,0.12);border-radius:2px;overflow:hidden;}
.progress-bar-fill{height:100%;width:0%;background:rgba(139,26,26,0.45);border-radius:2px;animation:fillBar 2s linear 0.4s forwards;}
@keyframes fillBar{0%{width:0%;}100%{width:100%;}}

/* eski 3 aşamalı zoom — wrap yerine img'e uygulanıyor (stacking context oluşturmasın diye) */
.seal-wrap.zooming .seal-img{
  animation:sealZoom 1.6s cubic-bezier(0.4,0,0.25,1) forwards;
}
@keyframes sealZoom{
  0%  {transform:scale(1);  opacity:1;}
  40% {transform:scale(2);  opacity:1;}
  70% {transform:scale(5);  opacity:1;}
  88% {transform:scale(11); opacity:1;}
  100%{transform:scale(20); opacity:0;}
}

/* ── MAIN SCROLL CONTAINER ── */
#invite{
  position:fixed;inset:0;z-index:5;
  opacity:0;pointer-events:none;
  overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
#invite.show{
  pointer-events:all;
  animation:inviteIn 1s cubic-bezier(0.4,0,0.2,1) forwards;
}
@keyframes inviteIn{0%{opacity:0;transform:scale(1.04);}100%{opacity:1;transform:scale(1);}}

/* ── DAVETIYE BÖLÜMÜ ── */
.section-invite{
  min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:52px 36px 80px;
  position:relative;
  background:linear-gradient(160deg,#faf7f2 0%,#f5f0e8 50%,#ede5d0 100%);
}
.section-invite::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 15% 15%,rgba(139,26,26,0.04) 0%,transparent 55%),
    radial-gradient(ellipse at 85% 85%,rgba(139,26,26,0.03) 0%,transparent 55%);
}
.fo{position:absolute;inset:14px;border:1px solid rgba(180,148,55,0.4);pointer-events:none;}
.fi{position:absolute;inset:22px;border:0.5px solid rgba(180,148,55,0.18);pointer-events:none;}
.c{position:absolute;font-size:16px;color:#b8910a;opacity:0;line-height:1;}
.c.tl{top:26px;left:30px}
.c.tr{top:26px;right:30px}
.c.bl{bottom:26px;left:30px}
.c.br{bottom:26px;right:30px}

.mini-seal{width:200px;height:200px;object-fit:cover;margin-bottom:24px;mix-blend-mode:multiply;opacity:0;}
.eyebrow{font-family:'Cinzel',serif;font-size:14px;font-weight:500;letter-spacing:6px;color:#8B1a1a;text-transform:uppercase;margin-bottom:26px;opacity:0;}
.names{font-family:'Cormorant Garamond',serif;font-size:56px;font-weight:300;color:#1a1208;line-height:1.15;text-align:center;opacity:0;}
.amp{display:block;font-size:70px;font-style:italic;color:#8B1a1a;line-height:1.1;margin:2px 0;}
.div{display:flex;align-items:center;gap:10px;margin:16px 0;width:180px;opacity:0;}
.dl{flex:1;height:0.5px;background:linear-gradient(to right,transparent,#c8a84b,transparent);}
.dd{width:6px;height:6px;flex-shrink:0;background:#c8a84b;transform:rotate(45deg);}
.body-t{font-family:'Cormorant Garamond',serif;font-size:17px;font-style:italic;color:#6b5520;line-height:1.85;text-align:center;max-width:280px;margin-bottom:20px;opacity:0;}
.date{font-family:'Cinzel',serif;font-size:13px;letter-spacing:3px;color:#1a1208;text-align:center;margin-bottom:5px;opacity:0;text-transform:uppercase;}
.time{font-family:'Cormorant Garamond',serif;font-size:15px;letter-spacing:1px;color:#8a6f30;text-align:center;margin-bottom:18px;opacity:0;line-height:1.6;}
.time-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:baseline;column-gap:10px;width:170px;margin:0 auto;}
.time-label{font-family:'Cinzel',serif;font-size:11px;letter-spacing:2.5px;color:#1a1208;text-transform:uppercase;text-align:right;}
.time-sep{color:#c8a84b;font-size:14px;line-height:1;transform:translateY(-1px);}
.time-val{font-family:'Cormorant Garamond',serif;font-size:16px;font-style:italic;color:#8a6f30;letter-spacing:1px;text-align:left;}
.venue{text-align:center;font-family:'Cormorant Garamond',serif;opacity:0;}
.vname{font-size:21px;font-weight:400;color:#1a1208;letter-spacing:1px;}
.vsub{font-size:16px;font-style:italic;color:#6b5520;letter-spacing:1.5px;margin-top:5px;}
.rsvp{margin-top:28px;font-family:'Cinzel',serif;font-size:8px;letter-spacing:3px;color:#8B1a1a;text-align:center;opacity:0;text-transform:uppercase;}

/* ── AŞAĞI OK ── */
.scroll-hint{
  position:absolute;
  bottom:24px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:6px;
  opacity:0;
  cursor:pointer;
  transition:opacity 0.45s ease, transform 0.45s cubic-bezier(0.4,0,0.2,1);
}
.scroll-hint.visible{ animation:hintFadeIn 0.8s 0.5s forwards; }
@keyframes hintFadeIn{from{opacity:0;transform:translateX(-50%) translateY(6px);}to{opacity:1;transform:translateX(-50%) translateY(0);}}
.scroll-hint.is-leaving{
  animation:none;
  opacity:0;
  transform:translateX(-50%) translateY(10px);
  pointer-events:none;
}

.scroll-label{
  font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;
  color:rgba(139,26,26,0.55);text-transform:uppercase;
}
.scroll-arrow{
  display:flex;flex-direction:column;align-items:center;gap:3px;
}
.arrow-line{
  width:1px;height:20px;
  background:linear-gradient(to bottom,transparent,rgba(139,26,26,0.5));
}
.arrow-chevron{
  width:12px;height:12px;
  border-right:1.5px solid rgba(139,26,26,0.55);
  border-bottom:1.5px solid rgba(139,26,26,0.55);
  transform:rotate(45deg);
  animation:chevBounce 1.5s ease-in-out infinite;
}
@keyframes chevBounce{0%,100%{transform:rotate(45deg) translateY(0);}50%{transform:rotate(45deg) translateY(3px);}}

/* ── HARİTA BÖLÜMÜ ── */
.section-map{
  min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;
  background:linear-gradient(180deg,#ede5d0 0%,#e8e0cc 100%);
  padding:52px 0 0;
}

.map-header{
  text-align:center;
  padding:0 32px 32px;
}
.map-eyebrow{
  font-family:'Cinzel',serif;font-size:9px;letter-spacing:5px;
  color:#b8910a;text-transform:uppercase;margin-bottom:16px;
}
.map-title{
  font-family:'Cormorant Garamond',serif;
  font-size:26px;font-weight:300;color:#1a1208;
  margin-bottom:6px;
}
.map-sub{
  font-family:'Cormorant Garamond',serif;
  font-size:17px;font-style:italic;color:#6b5520;
  letter-spacing:1.5px;
}

.map-divider{display:flex;align-items:center;gap:10px;margin:0 auto 28px;width:160px;}
.map-dl{flex:1;height:0.5px;background:linear-gradient(to right,transparent,#c8a84b,transparent);}
.map-dd{width:5px;height:5px;flex-shrink:0;background:#c8a84b;transform:rotate(45deg);}

.map-frame{
  width:100%;
  flex:1;
  min-height:380px;
  border:none;
  display:block;
}

.map-btn{
  display:flex;align-items:center;gap:8px;
  margin:24px auto 32px;
  padding:14px 28px;
  background:#8B1a1a;
  color:#fff8f0;
  font-family:'Cinzel',serif;font-size:10px;letter-spacing:3px;
  text-transform:uppercase;text-decoration:none;
  border-radius:2px;
  box-shadow:0 4px 20px rgba(139,26,26,0.3);
  transition:background 0.2s,transform 0.2s;
}
.map-btn:active{background:#6b1414;transform:scale(0.98);}
.map-btn svg{width:14px;height:14px;fill:none;stroke:#fff8f0;stroke-width:2;}

@keyframes fadeUp{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeCorner{from{opacity:0;}to{opacity:1;}}

/* ── FOTOĞRAF PAYLAŞIM BÖLÜMÜ ── */
.section-photos{
  width:100%;
  display:flex;flex-direction:column;align-items:center;
  padding:64px 24px 96px;
  background:linear-gradient(180deg,#e8e0cc 0%,#ede5d0 50%,#e0d6bc 100%);
  position:relative;
}
.section-photos::before{
  content:'';position:absolute;left:14px;right:14px;top:14px;bottom:14px;
  border:1px solid rgba(180,148,55,0.3);
  pointer-events:none;
}
.section-photos::after{
  content:'';position:absolute;left:22px;right:22px;top:22px;bottom:22px;
  border:0.5px solid rgba(180,148,55,0.15);
  pointer-events:none;
}

.photos-header{text-align:center;max-width:380px;}
.photos-eyebrow{
  font-family:'Cinzel',serif;font-size:9px;letter-spacing:5px;
  color:#b8910a;text-transform:uppercase;margin-bottom:18px;
}
.photos-title{
  font-family:'Cormorant Garamond',serif;
  font-size:26px;font-weight:300;color:#1a1208;
  line-height:1.3;margin-bottom:14px;
}
.photos-sub{
  font-family:'Cormorant Garamond',serif;
  font-size:15px;font-style:italic;color:#6b5520;
  line-height:1.7;margin-bottom:24px;
}

.photos-divider{display:flex;align-items:center;gap:10px;margin:0 auto 28px;width:160px;}
.photos-dl{flex:1;height:0.5px;background:linear-gradient(to right,transparent,#c8a84b,transparent);}
.photos-dd{width:5px;height:5px;flex-shrink:0;background:#c8a84b;transform:rotate(45deg);}

.photo-form{
  width:100%;max-width:440px;
  display:flex;flex-direction:column;gap:14px;
  z-index:1;
}

.photo-input{
  font-family:'Cormorant Garamond',serif;font-size:16px;
  padding:14px 18px;
  background:rgba(255,255,255,0.65);
  border:1px solid rgba(180,148,55,0.45);
  border-radius:2px;
  color:#1a1208;
  width:100%;
  outline:none;
  transition:border-color 0.2s, background 0.2s;
  -webkit-appearance:none;appearance:none;
}
.photo-input:focus{
  border-color:#8B1a1a;
  background:rgba(255,255,255,0.9);
}
.photo-input::placeholder{color:#a08830;font-style:italic;}

.photo-picker{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  padding:32px 20px;
  border:1.5px dashed rgba(139,26,26,0.4);
  border-radius:4px;
  background:rgba(255,255,255,0.45);
  cursor:pointer;
  transition:background 0.2s,border-color 0.2s,transform 0.15s;
  text-align:center;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.photo-picker:active{
  background:rgba(255,255,255,0.75);
  border-color:#8B1a1a;
  transform:scale(0.99);
}
.photo-picker svg{
  width:40px;height:40px;
  stroke:#8B1a1a;fill:none;stroke-width:1.5;
  stroke-linecap:round;stroke-linejoin:round;
}
.photo-picker-text{
  font-family:'Cormorant Garamond',serif;
  font-size:16px;color:#6b5520;font-style:italic;
}
.photo-picker-hint{
  font-family:'Cinzel',serif;font-size:9px;letter-spacing:3px;
  color:#8B1a1a;text-transform:uppercase;opacity:0.75;
}

.photo-input-file{
  position:absolute;width:1px;height:1px;
  padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);border:0;
}

.photo-thumbs{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(76px,1fr));
  gap:8px;
}
.photo-thumb{
  position:relative;
  aspect-ratio:1;
  border-radius:3px;overflow:hidden;
  background:#1a1208;
  border:1px solid rgba(180,148,55,0.4);
  box-shadow:0 2px 6px rgba(0,0,0,0.08);
  animation:thumbIn 0.25s ease;
}
@keyframes thumbIn{from{opacity:0;transform:scale(0.9);}to{opacity:1;transform:scale(1);}}
.photo-thumb img{
  width:100%;height:100%;object-fit:cover;
  display:block;
}
.photo-thumb-remove{
  position:absolute;top:4px;right:4px;
  width:24px;height:24px;
  background:rgba(20,8,2,0.75);
  color:#fff;
  border:none;border-radius:50%;
  font-size:18px;line-height:1;font-weight:300;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  padding:0;
  -webkit-tap-highlight-color:transparent;
}
.photo-thumb-remove:active{background:#8B1a1a;}

.photo-progress{
  width:100%;height:3px;
  background:rgba(139,26,26,0.12);
  border-radius:3px;overflow:hidden;
  display:none;
}
.photo-progress.show{display:block;}
.photo-progress-fill{
  height:100%;width:0%;
  background:#8B1a1a;
  border-radius:3px;
  transition:width 0.2s ease;
}

.photo-submit{
  margin-top:6px;
  padding:16px 28px;
  background:#8B1a1a;
  color:#fff8f0;
  font-family:'Cinzel',serif;font-size:11px;letter-spacing:3px;
  text-transform:uppercase;text-align:center;
  border:none;border-radius:2px;
  cursor:pointer;
  box-shadow:0 4px 20px rgba(139,26,26,0.3);
  transition:background 0.2s,transform 0.15s,opacity 0.2s;
  -webkit-appearance:none;appearance:none;
  min-height:48px;
}
.photo-submit:disabled{opacity:0.45;cursor:not-allowed;box-shadow:none;}
.photo-submit:not(:disabled):active{background:#6b1414;transform:scale(0.98);}

.photo-status{
  font-family:'Cormorant Garamond',serif;font-size:14px;
  text-align:center;min-height:22px;
  color:#6b5520;font-style:italic;
  line-height:1.5;
  padding:0 8px;
}
.photo-status.success{color:#5a6f1a;}
.photo-status.error{color:#8B1a1a;}

/* ── RESPONSIVE ── */
@media (max-width:480px){
  .section-photos{padding:48px 18px 80px;}
  .photos-title{font-size:23px;}
  .photos-sub{font-size:14px;}
  .photo-thumbs{grid-template-columns:repeat(auto-fill,minmax(68px,1fr));gap:6px;}
  .photo-picker{padding:26px 16px;}
  .photo-picker svg{width:34px;height:34px;}
  .photo-picker-text{font-size:15px;}
}
@media (min-width:768px){
  .section-photos{padding:80px 32px 120px;}
  .photos-title{font-size:30px;}
  .photo-form{max-width:480px;}
  .photo-thumbs{grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px;}
}
