/* Saba Bridal Shower — TRUE CLEAN v14
   Rule: each editable item has one main CSS block only.
   No bottom force rules. No split position/style blocks.
   To edit anything, search the class name and change top/left/right/width/font-size.
*/

:root{
  --green:#043f2f;
  --dark:#02271d;
  --pink:#ef7fa5;
  --cream:#fff8ee;
  --scale:1;
  --page-height:9550px;
}

/* =====================
   GLOBAL BASE
   ===================== */

*{
  box-sizing:border-box;
}

html,
body{
  margin:0;
  background:#fff1f5;
  color:var(--green);
  font-family:Inter,system-ui,sans-serif;
  overflow-x:hidden;
}

body{
  display:flex;
  justify-content:center;
}

.stage-wrap{
  width:100vw;
  max-width:1080px;
  overflow:hidden;
  background:var(--cream);
}

.artboard{
  position:relative;
  width:1080px;
  height:var(--page-height);
  transform-origin:top left;
  overflow:hidden;
  background:
    radial-gradient(circle at 72% 9%, rgba(240, 180, 200, 0.2), transparent 12%),
    radial-gradient(circle at 16% 30%, rgba(202,246,235,.28), transparent 15%),
    radial-gradient(circle at 82% 44%, rgba(239,127,165,.20), transparent 18%),
    linear-gradient(180deg, rgba(255,248,239,.26), rgba(255,248,239,.70) 34%, rgba(255,245,248,.60) 72%, rgba(255,248,239,.88)),
    repeating-linear-gradient(90deg, rgba(255,255,255,.96) 0px, rgba(255,255,255,.96) 54px, rgba(255,198,216,.48) 54px, rgba(255,198,216,.48) 102px);
}

.locked{
  filter:blur(10px) brightness(1.04);
  pointer-events:none;
}

h1,
h2,
h3,
p{
  margin:0;
}

.status{
  font-size:16px;
  color:var(--green);
  margin-top:12px;
}

/* =====================
   NAME SCREEN
   ===================== */

.name-screen{
  position:fixed;
  inset:0;
  z-index:100;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    linear-gradient(180deg,rgba(255,246,248,.74),rgba(255,246,248,.62)),
    repeating-linear-gradient(90deg,rgba(255,255,255,.95) 0 50px,rgba(255,198,216,.42) 50px 96px);
  backdrop-filter:blur(11px);
}

/* Name screen full opacity — same invite background */
.name-screen{
  background-color:#fff8ef !important;
  background-image:
    linear-gradient(
      180deg,
      rgba(255,248,239,.18),
      rgba(255,245,248,.20) 55%,
      rgba(255,248,239,.18)
    ),
    repeating-linear-gradient(
      90deg,
      #fffaf4 0px,
      #fffaf4 54px,
      #ffe4ec 54px,
      #ffe4ec 102px
    ) !important;

  opacity:1 !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}

body:has(#nameScreen) .back-to-top{
  display:none !important;
}


html:has(#nameScreen),
body:has(#nameScreen){
  overflow:hidden !important;
  height:100% !important;
  position:fixed !important;
  width:100% !important;
}

.name-inner{
  width:min(86vw,480px);
  min-height:min(1900px,92vh);
  display:flex;
  flex-direction:column;
  justify-content:center;
  text-align:center;
  color:var(--green);
}

.name-mini{
  font-family:"Josefin Sans",sans-serif;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-size:13px;
  color:var(--pink);
  font-weight:700;
  margin-bottom:24px;
}

.name-input{
  width:100%;
  border:0;
  border-bottom:1.5px solid rgba(4,63,47,.58);
  background:transparent;
  outline:0;
  text-align:center;
  padding:18px 4px;
  color:var(--green);
  font-size:23px;
}

.name-enter{
  border:0;
  background:transparent;
  margin:32px auto 0;
  padding:0;
  cursor:pointer;
}

.name-enter img{
  width:180px;
}

.name-hint{
  font-size:12px;
  color:#92776f;
  margin-top:20px;
}

/* =====================
   HERO SECTION
   ===================== */

.hero-section{
  position:absolute;
  top:0px;
  left:0px;
  width:1080px;
  height:2970px;
}

.hero-asset{
  position:absolute;
  display:block;
  pointer-events:none;
  filter:drop-shadow(0 18px 22px rgba(42,24,31,.14));
  will-change:transform,opacity;
}

.palm-hero{
  top:42px;
  left:-50px;
  width:355px;
  --float-y:0px;
  --float-x:0px;
  --float-rotation:0deg;
  --float-duration:4.6s;
}

.sign{
  top:105px;
  left:280px;
  width:520px;
  --float-y:10px;
  --float-x:4px;
  --float-rotation:.5deg;
  --float-duration:5.2s;
}

.umbrella{
  top:260px;
  right:-10px;
  width:365px;
  --float-y:15px;
  --float-x:10px;
  --float-rotation:1.5deg;
  --float-duration:5.8s;
}

.cherries-hero{
  top:960px;
  left:40px;
  width:145px;
  --float-y:20px;
  --float-x:12px;
  --float-rotation:5deg;
  --float-duration:3.7s;
}

.shell-hero{
  top:620px;
  left:170px;
  width:112px;
  --float-y:14px;
  --float-x:-10px;
  --float-rotation:-6deg;
  --float-duration:4.1s;
}

.camera-hero{
  top:1250px;
  left:78px;
  width:145px;
  --float-y:22px;
  --float-x:14px;
  --float-rotation:3deg;
  --float-duration:4.9s;
}

.glasses-hero{
  top:1390px;
  left:765px;
  width:145px;
  --float-y:18px;
  --float-x:-12px;
  --float-rotation:-7deg;
  --float-duration:3.9s;
}

.chaise-hero{
  top:870px;
  right:12px;
  width:275px;
  --float-y:12px;
  --float-x:-6px;
  --float-rotation:-1.5deg;
  --float-duration:6.1s;
}

.pool{
  top:1250px;
  right:-95px;
  width:450px;
  --float-y:8px;
  --float-x:4px;
  --float-rotation:.4deg;
  --float-duration:7s;
}

.pool-float-hero{
  top:1605px;
  right:285px;
  width:150px;
  --float-y:28px;
  --float-x:-14px;
  --float-rotation:12deg;
  --float-duration:3.4s;
}

.sparkle-hero{
  top:2780px;
  right:198px;
  width:95px;
  --float-y:30px;
  --float-x:18px;
  --float-rotation:16deg;
  --float-duration:2.9s;
}

.hi-label{
  position:absolute;
  top:530px;
  left:120px;
  width:840px;
  z-index:7;
  text-align:center;
  font-family:"Borel",cursive;
  font-size:60px;
  line-height:1;
  color:var(--green);
  opacity:0;
}

.hero-copy{
  position:absolute;
  top:650px;
  left:120px;
  width:840px;
  z-index:4;
  text-align:center;
}

.hero-line{
  position:absolute;
  left:0px;
  width:840px;
}

.hero-welcome{
  top:0px;
  font-family:"Borel",cursive;
  font-size:35px;
  line-height:1;
  letter-spacing:.09em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--pink);
}

.hero-saba{
  top:140px;
  font-family:"Borel",cursive;
  font-size:150px;
  line-height:.74;
  font-weight:400;
  color:var(--pink);
}

.hero-bridal{
  top:235px;
  font-family:"DM Serif Display",serif;
  font-size:78px;
  line-height:.95;
  letter-spacing:.05em;
  font-weight:400;
  color:var(--green);
}

.hero-divider{
  top:355px;
  left:240px;
  width:360px;
  filter:none;
}

.hero-sub{
  top:450px;
  font-family:"Josefin Sans",sans-serif;
  font-size:25px;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-weight:700;
  color:var(--green);
}

.hero-tag{
  top:520px;
  font-family:"Borel",cursive;
  font-size:30px;
  line-height:1.1;
  color:var(--dark);
}

.location-house-number{
  display:block;
  transform:translateY(1200px);
}



.capture-album-section::before{
  content:"";
  position:absolute;
  top:-120px;
  left:0;
  width:1080px;
  height:1050px;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 28%, rgba(255,214,227,.60), transparent 28%),
    radial-gradient(circle at 18% 42%, rgba(255,232,161,.25), transparent 18%),
    radial-gradient(circle at 82% 40%, rgba(202,246,235,.25), transparent 20%);
}

.capture-camera-wrap,
.capture-copy{
  z-index:2;
}

.capture-camera-img{
  filter:drop-shadow(0 24px 35px rgba(4,63,47,.12));
}

.capture-title::before,
.capture-title::after{
  content:"";
  display:inline-block;
  width:90px;
  height:1px;
  background:rgba(239,127,165,.55);
  vertical-align:middle;
  margin:0 18px;
}

.capture-copy::after{
  content:"♡";
  display:block;
  margin-top:22px;
  color:#f07aa0;
  font-family:"Borel",cursive;
  font-size:42px;
  line-height:1;
  opacity:.85;
}



/* =====================
   TIMELINE SECTION
   ===================== */

.timeline-section{
  position:absolute;
  top:3500px;
  left:0px;
  width:1080px;
  height:4050px;
  overflow:visible;
}

.timeline-title{
  position:absolute;
  top:50px;
  left:0px;
  width:1080px;
  text-align:center;
  font-family:"DM Serif Display",serif;
  font-size:52px;
  letter-spacing:.035em;
  font-weight:400;
  color:var(--green);
}

.timeline-title::before,
.timeline-title::after{
  content:"";
  display:inline-block;
  width:135px;
  height:1px;
  background:rgba(239,127,165,.6);
  vertical-align:middle;
  margin:0 22px;
}

.timeline-divider{
  position:absolute;
  top:150px;
  left:385px;
  width:300px;
  filter:none;
}

.timeline-line{
  position:absolute;
  top:250px;
  left:540px;
  width:4px;
  height:2670px;
  background:linear-gradient(var(--dark),var(--green),var(--dark));
  box-shadow:0 0 0 1px rgba(255,255,255,.55);
}

.timeline-dot{
  position:absolute;
  left:514px;
  width:56px;
  height:56px;
  z-index:5;
}

.timeline-dot::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  background:#f5c7d6;
}

.timeline-dot::after{
  content:"";
  position:absolute;
  left:12px;
  top:12px;
  width:32px;
  height:32px;
  border-radius:50%;
  background:var(--green);
  box-shadow:inset 0 0 0 4px #a87e2a;
}

.dot-1{
  top:450px;
}

.dot-2{
  top:1000px;
}

.dot-3{
  top:1500px;
}

.dot-4{
  top:2050px;
}

.dot-5{
  top:2600px;
}

.timeline-arrow{
  display:none;
  position:absolute;
  width:245px;
  opacity:0;
  z-index:4;
  pointer-events:none;
  filter:drop-shadow(0 4px 4px rgba(4,63,47,.10));
  will-change:transform,opacity;
}




.timeline-decor{
  position:absolute;
  display:block;
  pointer-events:none;
  filter:drop-shadow(0 18px 22px rgba(42,24,31,.14));
  will-change:transform,opacity;
}

.decor-cherries{
  top:340px;
  left:7080px;
  width:130px;
}

.decor-shell{
  top:5540px;
  right:2900px;
  width:130px;
}

.decor-cloche{
  top:700px;
  left:750px;
  width:215px;
}

.decor-lemon-pie{
  top:1210px;
  right:80px;
  width:150px;
}

.decor-float{
  top:1450px;
  left:260px;
  width:190px;
}

.decor-floral{
  top:1800px;
  right:70px;
  width:230px;
}

.decor-palm{
  top:2250px;
  left:70px;
  width:250px;
}

.decor-divider{
  top:4650px;
  left:265px;
  width:540px;
}

.timeline-event{
  position:absolute;
  width:410px;
  z-index:3;
  color:var(--green);
}

.event-photo{
  top:300px;
  left:190px;
}

.event-lunch{
  top:900px;
  left:625px;
}

.event-pool{
  top:1450px;
  left:200px;
}

.event-dj{
  top:1800px;
  left:625px;
}

.event-shower{
  top:2500px;
  left:140px;
}

.event-image{
  display:block;
  filter:drop-shadow(0 18px 20px rgba(42,24,31,.15));
}

.event-photo-image{
  width:245px;
}

.event-lunch-image{
  width:290px;
}

.event-pool-image{
  width:235px;
}

.event-dj-image{
  width:238px;
}

.event-shower-image{
  width:342px;
}

.event-time{
  position:static;
  margin:16px 0 4px;
  font-family:"Borel",cursive;
  font-size:35px;
  line-height:1;
  color:var(--pink);
}

.event-title{
  position:static;
  font-family:"Borel",cursive;
  font-size:34px;
  line-height:1.03;
  font-weight:400;
  color:var(--green);
}

.menu-word-button{
  margin-top:14px;
  border:0;
  background:transparent;
  padding:0;
  color:var(--pink);
  font-family:"Borel",cursive;
  font-size:31px;
  text-decoration:underline;
  text-underline-offset:7px;
  cursor:pointer;
  pointer-events:auto;
}

.menu-word-button::after{
  content:" 〰";
  color:var(--green);
}


/* =====================
   NOTE SECTION — EDITABLE SVG TALL VERSION
   ===================== */

.note-section{
  position:absolute;
  top:6200px;
  left:0px;
  width:1080px;
  height:1400px;
  overflow:visible;
}

.note-svg-stage{
  position:absolute;
  top:0px;
  left:70px;
  width:940px;
  height:1500px;
  z-index:1;
  pointer-events:none;
  overflow:hidden;
}

.note-svg-stage svg{
  display:block;
  width:940px;
  height:1560px;
  overflow:visible;
}

/* Photo areas */
.note-photo-slot{
  position:absolute;
  z-index:3;
  background:transparent;
  overflow:hidden;
  pointer-events:none;
}

.note-photo-image{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* assets/note-left.png */
.note-photo-left{
  top:122px;
  left:200px;
  width:225px;
  height:276px;
}

/* assets/note-right.png */
.note-photo-right{
  top:796px;
  left:674px;
  width:224px;
  height:313px;
}

/* Invisible form layer */
.note-form{
  position:absolute;
  top:374px;
  left:401px;
  width:688px;
  height:480px;
  z-index:6;
  text-align:left;
}

/* Invisible button over SEND NOTE */
.note-send-hotspot{
  position:absolute;
  top:0px;
  left:0px;
  width:235px;
  height:47px;
  border:0;
  background:rgba(255, 0, 0, 0);
  color:transparent;
  cursor:pointer;
  padding:0;
}

/* Textarea over the writing lines */
.note-textarea{
  position:absolute;
  top:115px;
  left:-170px;
  width:630px;
  height:300px;
  resize:none;
  outline:0;
  border:0;
  background:transparent;
  box-shadow:none;
  color:#ffe7ec;
  padding:28px 36px;
  font-family:"Josefin Sans",sans-serif;
  text-transform:none;
  letter-spacing:.03em;
  font-size:35px;
  line-height:1.75;
}

.note-textarea::placeholder{
  color:rgba(255,231,236,.78);
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:13px;
}

/* Message after sending */
.note-status{
  position:absolute;
  top:532px;
  left:-218px;
  width:688px;
  color:#ffe7ec;
  font-family:"Josefin Sans",sans-serif;
  text-transform:uppercase;
  letter-spacing:.10em;
  font-size:11px;
  line-height:1.5;
}

.write-another-note{
  border:0;
  background:transparent;
  color:#ffd7df;
  font-family:"Josefin Sans",sans-serif;
  text-transform:uppercase;
  letter-spacing:.10em;
  font-size:10px;
  text-decoration:underline;
  text-underline-offset:5px;
  cursor:pointer;
  margin-left:8px;
}

/* Sent notes below the SVG */
.my-notes-wall{
  position:absolute;
  top:1310px;
  left:180px;
  width:720px;
  min-height:120px;
  z-index:7;
}

.my-notes-label{
  display:none;
}

.my-notes-list{
  position:relative;
  min-height:90px;
}

.my-note-card{
  position:relative;
  display:inline-block;
  max-width:260px;
  margin:7px;
  padding:12px 14px;
  border:1px solid rgba(15,74,49,.30);
  background:rgba(255,246,240,.82);
  color:#0f4a31;
  font-family:"Cormorant Garamond",serif;
  font-size:19px;
  line-height:1.25;
  text-transform:none;
  letter-spacing:.01em;
  box-shadow:0 8px 24px rgba(6,37,22,.12);
  border-radius:12px;
}

.note-card-1{ transform:rotate(-2.4deg); }
.note-card-2{ transform:rotate(2deg); }
.note-card-3{ transform:rotate(-1.4deg); }
.note-card-4{ transform:rotate(1.8deg); }

/* SVG animations */
.note-svg-stage .note-svg-float,
.note-svg-stage .note-svg-rise,
.note-svg-stage .note-svg-fade{
  transform-box:fill-box;
  transform-origin:center;
}

.note-svg-stage .note-svg-float-1{ animation:noteFloat1 5.6s ease-in-out infinite; }
.note-svg-stage .note-svg-float-2{ animation:noteFloat2 4.8s ease-in-out infinite; }
.note-svg-stage .note-svg-float-3{ animation:noteFloat3 6s ease-in-out infinite; }
.note-svg-stage .note-svg-float-4{ animation:noteFloat4 5.2s ease-in-out infinite; }
.note-svg-stage .note-svg-float-5{ animation:noteFloat5 4.4s ease-in-out infinite; }
.note-svg-stage .note-svg-float-6{ animation:noteFloat6 6.6s ease-in-out infinite; }
.note-svg-stage .note-svg-rise{ animation:noteRise 1.2s ease both; }
.note-svg-stage .note-svg-delay{ animation-delay:.18s; }
.note-svg-stage .note-svg-fade{ animation:noteFade 2.4s ease-in-out infinite alternate; }

@keyframes noteFloat1{
  0%,100%{ transform:translateY(0px) rotate(-0.5deg); }
  50%{ transform:translateY(-9px) rotate(0.9deg); }
}

@keyframes noteFloat2{
  0%,100%{ transform:translateY(0px) rotate(-1deg); }
  50%{ transform:translateY(8px) rotate(1deg); }
}

@keyframes noteFloat3{
  0%,100%{ transform:translateY(0px) rotate(0.7deg); }
  50%{ transform:translateY(-8px) rotate(-0.8deg); }
}

@keyframes noteFloat4{
  0%,100%{ transform:translateY(0px) rotate(0deg); }
  50%{ transform:translateY(7px) rotate(-1deg); }
}

@keyframes noteFloat5{
  0%,100%{ transform:translateY(0px); }
  50%{ transform:translateY(-6px); }
}

@keyframes noteFloat6{
  0%,100%{ transform:translateY(0px) rotate(-0.6deg); }
  50%{ transform:translateY(-10px) rotate(0.6deg); }
}

@keyframes noteRise{
  from{ opacity:0; transform:translateY(16px); }
  to{ opacity:1; transform:translateY(0); }
}

@keyframes noteFade{
  from{ opacity:.84; }
  to{ opacity:1; }
}


/* =====================
   CAPTURE ALBUM SECTION — PNG CAMERA
   ===================== */

.capture-album-section{
  position:absolute;
  top:8300px;
  left:0px;
  width:1080px;
  height:900px;
  overflow:visible;
  background:transparent;
  color:var(--green);
}

/* whole camera image area */
.capture-camera-wrap{
  position:absolute;
  top:40px;
  left:40px;
  width:1500px;
  height:500px;
}

/* transparent PNG camera */
.capture-camera-img{
  position:absolute;
  top:0px;
  left:-300px;
  width:1500px;
  height:auto;
  display:block;
}

/* clickable album button, separate from PNG */
.capture-album-button{
  position:absolute;
  top:30px;
  left:260px;
  width:500px;
  height:300px;
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  z-index:5;
}

/* temporary red circle so you can see location */
.capture-temp-circle{
  position:absolute;
  inset:0;
  border-radius:999px;
  background:red;
  opacity:.0;
  z-index:1;

}

/* pink flower icon */
.capture-flower-icon{
  position:relative;
  display:none;
  width:74px;
  height:74px;
  z-index:2;
}

.capture-petal{
  position:absolute;
  left:26px;
  top:4px;
  width:24px;
  height:41px;
  border-radius:999px 999px 12px 12px;
  background:rgba(239,127,165,.78);
  transform-origin:50% 33px;
  mix-blend-mode:multiply;
}

.capture-petal-1{ transform:rotate(0deg); }
.capture-petal-2{ transform:rotate(45deg); }
.capture-petal-3{ transform:rotate(90deg); }
.capture-petal-4{ transform:rotate(135deg); }
.capture-petal-5{ transform:rotate(180deg); }
.capture-petal-6{ transform:rotate(225deg); }
.capture-petal-7{ transform:rotate(270deg); }
.capture-petal-8{ transform:rotate(315deg); }

.capture-flower-center{
  position:absolute;
  left:31px;
  top:31px;
  width:15px;
  height:15px;
  border-radius:999px;
  background:#fff8ee;
  z-index:3;
}

.capture-tap-text{
  position:absolute;
  top:124px;
  left:50%;
  transform:translateX(-50%);
  width:150px;
  color:var(--green);
  font-family:"Josefin Sans",sans-serif;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:13px;
  font-weight:700;
  text-align:center;
  z-index:4;
  display:none;
}
.capture-camera-wrap::after{
  content:"Tap here";
  position:absolute;
  top:330px;
  left:510px;
  transform:translateX(-50%);
  z-index:6;

  color:var(--green);
  font-family:"Josefin Sans",sans-serif;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:30px;
  font-weight:700;
  text-align:center;

  pointer-events:none;
}
/* personalized wording under the camera */
.capture-copy{
  position:absolute;
  top:470px;
  left:130px;
  width:820px;
  text-align:center;
  color:var(--green);
}

.capture-title{
  margin:0 0 46px;
  color:var(--green);
  font-family:"DM Serif Display",serif;
  font-size:58px;
  line-height:1;
  font-weight:400;
}

.capture-line{
  margin:0 0 58px;
  color:var(--green);
}

.capture-line-1{
  font-family:"Josefin Sans",sans-serif;
  text-transform:uppercase;
  letter-spacing:.15em;
  font-size:27px;
  line-height:1.25;
  font-weight:700;
}

.capture-line-2{
  margin-top:22px;
  font-family:"Borel",cursive;
  font-size:28px;
  line-height:1.22;
  font-weight:400;
}

.album-status{
  margin-top:18px;
  color:var(--green);
}
/* =====================
   FOOTER
   ===================== */

.footer{
  position:absolute;
  top:9400px;
  left:0px;
  width:1080px;
  text-align:center;
  color:var(--green);
}

.footer-instagram{
  color:var(--green);
  text-decoration:none;
  font-size:18px;
  font-weight:500;
}

.footer-copyright{
  font-size:16px;
  color:#6c776f;
  margin-top:12px;
}

/* =====================
   MENU MODAL
   ===================== */

.menu-dialog{
  border:0;
  background:transparent;
  padding:0;
}

.menu-dialog::backdrop{
  background:rgba(14,22,19,.46);
  backdrop-filter:blur(10px);
}

.menu-modal{
  width:min(90vw,430px);
  height:min(86vh,760px);
  overflow:hidden;
  background:transparent;
}

.menu-close{
  position:fixed;
  right:30px;
  top:8px;
  border:0;
  background:rgba(255,248,239,.72);
  color:var(--green);
  font-size:34px;
  line-height:1;
  padding:5px 14px;
  cursor:pointer;
}

.menu-card{
  position:relative;
  min-height:760px;
  padding:40px 30px 40px;
  color:#b55363;
  background:rgba(255,238,241,.96);
  box-shadow:0 26px 90px rgba(0,0,0,.24);
  clip-path:path("M 52 8 C 95 20 118 4 164 10 C 210 17 238 6 281 11 C 331 16 354 4 389 29 C 414 48 398 85 409 128 C 420 174 402 199 410 242 C 419 291 402 318 409 360 C 417 407 402 438 410 485 C 420 544 396 573 407 625 C 420 684 397 718 408 775 C 419 833 401 873 365 897 C 326 923 296 901 251 911 C 201 922 173 899 127 907 C 84 914 52 899 31 864 C 6 823 24 788 13 738 C 4 694 22 661 13 615 C 3 562 24 530 14 478 C 4 425 23 393 14 343 C 5 294 23 263 14 219 C 4 171 21 143 13 99 C 5 57 17 24 52 8 Z");
  transform:scale(.88);
}

.menu-heading{
  font-family:"Parisienne",cursive;
  font-size:50px;
  color:#bd5162;
  text-align:center;
  font-weight:400;
  margin:0 0 26px;
}

.menu-section{
  display:block;
  text-align:center;
  margin:0 0 36px;
}

.menu-section-title{
  font-family:"Borel",cursive;
  color:#bd5162;
  font-size:25px;
  font-weight:300;
  margin:0 0 8px;
  line-height:1;
}

.menu-items{
  font-family:"Josefin Sans",sans-serif;
  text-transform:uppercase;
  color:#bd5162;
  font-size:10px;
  line-height:1.55;
  letter-spacing:.06em;
  font-weight:700;
}

.menu-note{
  font-family:"Borel",cursive;
  color:#bd5162;
  font-size:13px;
  line-height:1.25;
  text-align:center;
  margin-top:18px;
}

/* =====================
   MOBILE SCALING
   ===================== */

@media(max-width:1079px){
  .artboard{
    transform:scale(var(--scale));
  }

  .stage-wrap{
    height:calc(var(--page-height) * var(--scale));
  }
}


/* =========================================================
   NOTE SVG CSS EDIT CONTROLS — v18
   These controls do NOT change the current visual position by default.
   Edit only the variables below to move/resize note SVG parts from CSS.
   ========================================================= */

:root{
  /* Whole section */
  --note-section-top:6700px;
  --note-section-left:0px;
  --note-section-width:1080px;
  --note-section-height:2000px;

  /* Whole green SVG box */
  --note-stage-top:0px;
  --note-stage-left:70px;
  --note-stage-width:940px;
  --note-stage-height:1260px;

  /* CSS-only movement/scale for SVG groups.
     translate values move each item without touching HTML.
     scale values resize each item without touching HTML. */
  --note-left-frame-x:-40px;
  --note-left-frame-y:-30px;
  --note-left-frame-scale:1.1;

  --note-left-paperclip-x:0px;
  --note-left-paperclip-y:10px;
  --note-left-paperclip-scale:1;

  --note-heading-x:00px;
  --note-heading-y:0px;
  --note-heading-scale:1.2;

  --note-private-line-x:120px;
  --note-private-line-y:10px;
  --note-private-line-scale:1.1;

  --note-send-pill-x:280px;
  --note-send-pill-y:30px;
  --note-send-pill-scale:1;

  --note-writing-frame-x:0px;
  --note-writing-frame-y:0px;
  --note-writing-frame-scale-x:1;
  --note-writing-frame-scale-y:1;

  --note-right-frame-x:70px;
  --note-right-frame-y:120px;
  --note-right-frame-scale:1;

  --note-right-paperclip-x:100px;
  --note-right-paperclip-y:1150px;
  --note-right-paperclip-scale:1;

  --note-script-x:-90px;
  --note-script-y:250px;
  --note-script-scale:0.9;

  /* Actual uploaded picture slots.
     These are separate HTML image layers on top of the SVG frames. */
  --note-left-photo-top:80px;
  --note-left-photo-left:124px;
  --note-left-photo-width:247px;
  --note-left-photo-height:306px;

  --note-right-photo-top:900px;
  --note-right-photo-left:736px;
  --note-right-photo-width:224px;
  --note-right-photo-height:313px;

  /* Form / typing area */
  --note-form-top:374px;
  --note-form-left:451px;
  --note-form-width:200px;
  --note-form-height:480px;

  --note-send-click-top:0px;
  --note-send-click-left:0px;
  --note-send-click-width:235px;
  --note-send-click-height:47px;

  --note-textarea-top:115px;
  --note-textarea-left:-218px;
  --note-textarea-width:620px;
  --note-textarea-height:392px;
  --note-textarea-font-size:35px;
  --note-textarea-padding:28px 36px;

  --note-placeholder-font-size:25px;
  --note-placeholder-letter-spacing:.08em;

  --note-status-top:532px;
  --note-status-left:-218px;
  --note-status-width:688px;

  /* Submitted notes */
  --note-wall-top:1010px;
  --note-wall-left:180px;
  --note-wall-width:820px;

  --note-card-max-width:260px;
  --note-card-padding:12px 14px;
  --note-card-margin:7px;
  --note-card-font-size:27px;
  --note-card-radius:12px;
}

/* Apply the controls */
.note-section.note-svg-section,
.note-section{
  top:var(--note-section-top);
  left:var(--note-section-left);
  width:var(--note-section-width);
  height:var(--note-section-height);
}

.note-svg-stage{
  top:var(--note-stage-top);
  left:var(--note-stage-left);
  width:var(--note-stage-width);
  height:var(--note-stage-height);
}

.note-svg-stage svg{
  width:var(--note-stage-width);
  height:var(--note-stage-height);
}

/* SVG item controls */
.note-svg-stage #left-photo-frame{
  transform:translate(var(--note-left-frame-x), var(--note-left-frame-y)) scale(var(--note-left-frame-scale));
}

.note-svg-stage #left-paperclip{
  transform:translate(var(--note-left-paperclip-x), var(--note-left-paperclip-y)) scale(var(--note-left-paperclip-scale));
}

.note-svg-stage #heading{
  transform:translate(var(--note-heading-x), var(--note-heading-y)) scale(var(--note-heading-scale));
}

.note-svg-stage #private-line{
  transform:translate(var(--note-private-line-x), var(--note-private-line-y)) scale(var(--note-private-line-scale));
}

.note-svg-stage #send-note-pill{
  transform:translate(var(--note-send-pill-x), var(--note-send-pill-y)) scale(var(--note-send-pill-scale));
}

.note-svg-stage #writing-frame{
  transform:translate(var(--note-writing-frame-x), var(--note-writing-frame-y)) scale(var(--note-writing-frame-scale-x), var(--note-writing-frame-scale-y));
}

.note-svg-stage #right-photo-frame{
  transform:translate(var(--note-right-frame-x), var(--note-right-frame-y)) scale(var(--note-right-frame-scale));
}

.note-svg-stage #right-paperclip{
  transform:translate(var(--note-right-paperclip-x), var(--note-right-paperclip-y)) scale(var(--note-right-paperclip-scale));
}

.note-svg-stage #script-words{
  transform:translate(var(--note-script-x), var(--note-script-y)) scale(var(--note-script-scale));
}

/* Keep SVG transforms predictable */
.note-svg-stage #left-photo-frame,
.note-svg-stage #left-paperclip,
.note-svg-stage #heading,
.note-svg-stage #private-line,
.note-svg-stage #send-note-pill,
.note-svg-stage #writing-frame,
.note-svg-stage #right-photo-frame,
.note-svg-stage #right-paperclip,
.note-svg-stage #script-words{
  transform-box:fill-box;
  transform-origin:center;
}

/* Photo slots controlled by variables */
.note-photo-left{
  top:var(--note-left-photo-top);
  left:var(--note-left-photo-left);
  width:var(--note-left-photo-width);
  height:var(--note-left-photo-height);
}

.note-photo-right{
  top:var(--note-right-photo-top);
  left:var(--note-right-photo-left);
  width:var(--note-right-photo-width);
  height:var(--note-right-photo-height);
}

/* Form / textarea / button controls */
.note-form{
  top:var(--note-form-top);
  left:var(--note-form-left);
  width:var(--note-form-width);
  height:var(--note-form-height);
}

.note-send-hotspot{
  top:var(--note-send-click-top);
  left:var(--note-send-click-left);
  width:var(--note-send-click-width);
  height:var(--note-send-click-height);
}

.note-textarea{
  top:var(--note-textarea-top);
  left:var(--note-textarea-left);
  width:var(--note-textarea-width);
  height:var(--note-textarea-height);
  font-size:var(--note-textarea-font-size);
  padding:var(--note-textarea-padding);
}

.note-textarea::placeholder{
  font-size:var(--note-placeholder-font-size);
  letter-spacing:var(--note-placeholder-letter-spacing);
}

.note-status{
  top:var(--note-status-top);
  left:var(--note-status-left);
  width:var(--note-status-width);
}

.my-notes-wall{
  top:var(--note-wall-top);
  left:var(--note-wall-left);
  width:var(--note-wall-width);
}

.my-note-card{
  max-width:var(--note-card-max-width);
  margin:var(--note-card-margin);
  padding:var(--note-card-padding);
  font-size:var(--note-card-font-size);
  border-radius:var(--note-card-radius);
}


/* The SVG parts are now position-controlled by CSS variables.
   Their previous transform animations are disabled so movement variables always work. */
.note-svg-stage #left-photo-frame,
.note-svg-stage #left-paperclip,
.note-svg-stage #heading,
.note-svg-stage #private-line,
.note-svg-stage #send-note-pill,
.note-svg-stage #writing-frame,
.note-svg-stage #right-photo-frame,
.note-svg-stage #right-paperclip,
.note-svg-stage #script-words{
  animation:none;
}


.note-section::before{
  content:"";
  position:absolute;
  top:-30px;
  left:50px;
  width:980px;
  height:1320px;
  z-index:0;
  background:
    repeating-linear-gradient(
      330deg,
      #0f4a31 0px,
      #0f4a31 34px,
      #fff9f0 34px,
      #fff9f0 68px
    );
  opacity:1;
  pointer-events:none;
}



.hero-index{
  position:absolute;
  top:800px;
  right:250px;
  width:600px;
  z-index:15;
  display:flex;
  flex-direction:column;
  gap:10px;
  text-align:left;
}

.hero-index a{
  position:relative;
  display:block;
  padding-left:30px;
  color:var(--green);
  font-family:"DM Serif Display",serif;
  font-size:45px;
  line-height:1.02;
  letter-spacing:.01em;
  text-transform:none;
  text-decoration:none;
  font-weight:400;
  text-align:left;
}

.hero-index a::before{
  content:"→";
  position:absolute;
  left:0;
  top:10px;
  color:var(--pink);
  font-family:"Josefin Sans",sans-serif;
  font-size:50px;
  line-height:1;
  transform:translateX(-30px);
}

.hero-index a:hover{
  color:var(--pink);
}

/* =====================
   INSTRUCTIONS POPUP — CLEAN FINAL
   ===================== */

.instructions-trigger{
  position:absolute;
  top:8600px;
  right:70px;
  z-index:30;
  border:0;
  background:transparent;
  padding:0;
  color:var(--green);
  font-family:"Josefin Sans",sans-serif;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:20px;
  font-weight:700;
  text-decoration:underline;
  text-underline-offset:5px;
  cursor:pointer;
}

.instructions-dialog{
  border:0;
  background:transparent;
  padding:0;
}

.instructions-dialog::backdrop{
  background:rgba(14,22,19,.35);
  backdrop-filter:blur(6px);
}

.instructions-modal{
  position:relative;
  width:min(96vw,620px);
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
  overflow:visible !important;
}

.instructions-image{
  display:block;
  width:100%;
  height:auto;
  background:transparent !important;
  border-radius:0;
}

.instructions-close{
  position:absolute;
  top:-54px;
  right:-4px;
  width:46px;
  height:46px;
  border:0;
  background:transparent;
  color:var(--green);
  font-size:46px;
  line-height:1;
  cursor:pointer;
  z-index:5;
}


/* =====================
   LOCATION SECTION — CLEAN FINAL
   ===================== */

.location-section{
  position:absolute;
  top:2200px;
  left:0px;
  width:1080px;
  height:1300px;
  z-index:8;
  overflow:visible;
  background:transparent;
}

.location-link{
  position:absolute;
  top:0px;
  left:130px;
  width:880px;
  height:1200px;
  display:block;
  text-decoration:none;
  color:var(--green);
  overflow:visible;
}

.location-image{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;

  -webkit-mask-image:
    radial-gradient(
      ellipse 50% 50% at center,
      #000 60%,
      rgba(0,0,0,.75) 78%,
      transparent 100%
    );
  mask-image:
    radial-gradient(
      ellipse 50% 50% at center,
      #000 60%,
      rgba(0,0,0,.75) 78%,
      transparent 100%
    );
}

.location-link::after{
  display:none;
}

.location-tap{
  position:absolute;
  top:-40px;
  left:70%;
  transform:translateX(-50%) rotate(-2deg);
  z-index:3;
  color:#f07aa0;
  font-family:"Borel", cursive;
  font-size:58px;
  line-height:1.05;
  font-weight:400;
  text-shadow:
    0 2px 0 rgba(255,250,241,.95),
    0 10px 24px rgba(0,0,0,.18);
  white-space:nowrap;
  pointer-events:none;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
}


/* =====================
   BRIDE NOTES — CLEAN FINAL
   ===================== */

body.bride-page #noteForm,
body.bride-page #noteText,
body.bride-page #noteStatus,
body.bride-page .note-send-hotspot,
body.bride-page #send-note-pill,
body.bride-page #writing-frame,
body.bride-page .my-notes-wall{
  display:none !important;
}

body.bride-page .bride-notes-wall{
  position:absolute;
  top:505px;
  left:120px;
  width:840px;
  height:460px;
  z-index:24;
  display:flex;
  flex-wrap:wrap;
  align-content:flex-start;
  justify-content:center;
  gap:22px;
  overflow:visible;
  pointer-events:none;
}

body.bride-page .bride-note-card{
  position:relative;
  width:max-content;
  min-width:210px;
  max-width:390px;
  min-height:180px;
  padding:54px 52px 46px;
  background:transparent;
  color:#0f4a31;
  box-shadow:none;
  border-radius:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  transform:rotate(-4deg);
}

body.bride-page .bride-note-card::before{
  content:"♥";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  z-index:-1;
  color:#ffd6e3;
  opacity:.34;
  font-family:Georgia, serif;
  font-size:260px;
  line-height:1;
  text-shadow:0 10px 24px rgba(6,37,22,.08);
}

body.bride-page .bride-note-card:nth-child(even){
  transform:rotate(4deg);
}

body.bride-page .bride-note-card:nth-child(3n){
  transform:rotate(-1deg);
}

body.bride-page .bride-note-text{
  order:1;
  margin:0 0 12px;
  max-width:300px;
  font-family:"Borel", cursive;
  font-size:28px;
  line-height:1.08;
  color:#0f4a31;
}

body.bride-page .bride-note-name{
  order:2;
  margin:0;
  font-family:"Josefin Sans", sans-serif;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:13px;
  line-height:1.1;
  font-weight:700;
  color:#0f4a31;
}

body.bride-page .bride-note-empty{
  margin:70px auto 0;
  width:520px;
  text-align:center;
  font-family:"Borel",cursive;
  font-size:27px;
  line-height:1.22;
  color:#ffe7ec;
}


/* =====================
   PAGE SAFETY — CLEAN FINAL
   ===================== */

html,
body{
  background:#fff1f5;
  min-height:0 !important;
}

.stage-wrap{
  height:calc(var(--page-height) * var(--scale)) !important;
  max-height:calc(var(--page-height) * var(--scale)) !important;
  overflow:hidden !important;
}

.artboard{
  height:var(--page-height) !important;
  min-height:var(--page-height) !important;
  max-height:var(--page-height) !important;
  overflow:hidden !important;
}


body{
  margin:0;
}


/* =====================
   FINAL BEHAVIOR PATCH — v31
   ===================== */

/* Two moving arrows at the end of hero for the first 15 seconds only */
.scroll-hint{
  position:absolute;
  top:1880px;
  left:50%;
  transform:translateX(-50%) rotate(90deg);
  z-index:40;
  display:flex;
  gap:2px;
  color:var(--pink);
  font-family:"Josefin Sans",sans-serif;
  font-size:70px;
  font-weight:700;
  line-height:1;
  opacity:0;
  animation:scrollHintShow 15s ease forwards;
  pointer-events:none;
}

.scroll-hint span{
  animation:scrollHintMove 1.1s ease-in-out infinite;
}

.scroll-hint span:nth-child(2){
  animation-delay:.16s;
}

@keyframes scrollHintShow{
  0%{ opacity:0; }
  8%{ opacity:.95; }
  82%{ opacity:.95; }
  100%{ opacity:0; }
}

@keyframes scrollHintMove{
  0%,100%{ transform:translateX(0); }
  50%{ transform:translateX(14px); }
}

/* Floating back-to-top icon */
.back-to-top{
  position:fixed;
  right:22px;
  bottom:24px;
  z-index:90;
  width:42px;
  height:42px;
  border:1px solid rgba(4,63,47,.22);
  border-radius:999px;
  background:rgba(255,248,238,.72);
  backdrop-filter:blur(8px);
  color:var(--green);
  font-family:"Josefin Sans",sans-serif;
  font-size:10px;
  line-height:42px;
  text-align:center;
  padding:0;
  cursor:pointer;
  opacity:.88;
}

/* Bigger/centered instructions image, no card behind it */
.instructions-modal{
  width:min(100vw,860px) !important;
  max-width:860px !important;
  margin:auto !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
  overflow:visible !important;
}

.instructions-image{
  display:block;
  width:100%;
  height:auto;
  margin:0 auto;
  background:transparent !important;
  border-radius:0 !important;
}

.instructions-close{
  top:-58px !important;
  right:0px !important;
  width:50px !important;
  height:50px !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  font-size:50px !important;
  line-height:1 !important;
  z-index:5;
}

/* Make album section a little more immersive without moving existing parts */
.capture-album-section::before{
  content:"";
  position:absolute;
  top:-120px;
  left:0;
  width:1080px;
  height:1050px;
  z-index:0;
  pointer-events:none;
  background:
    radial-gradient(circle at 50% 28%, rgba(255,214,227,.60), transparent 28%),
    radial-gradient(circle at 18% 42%, rgba(255,232,161,.25), transparent 18%),
    radial-gradient(circle at 82% 40%, rgba(202,246,235,.25), transparent 20%);
}

.capture-camera-wrap,
.capture-copy{
  z-index:2;
}

.capture-camera-img{
  filter:drop-shadow(0 24px 35px rgba(4,63,47,.12));
}

.capture-title::before,
.capture-title::after{
  content:"";
  display:inline-block;
  width:90px;
  height:1px;
  background:rgba(239,127,165,.55);
  vertical-align:middle;
  margin:0 18px;
}

.capture-copy::after{
  content:"♡";
  display:block;
  margin-top:22px;
  color:#f07aa0;
  font-family:"Borel",cursive;
  font-size:42px;
  line-height:1;
  opacity:.85;
}

/* Stop the blank area after the footer by making wrapper and artboard use the same page height */
.stage-wrap{
  height:calc(var(--page-height) * var(--scale)) !important;
  max-height:calc(var(--page-height) * var(--scale)) !important;
  overflow:hidden !important;
}

.artboard{
  height:var(--page-height) !important;
  min-height:var(--page-height) !important;
  max-height:var(--page-height) !important;
  overflow:hidden !important;
}


/* =====================
   NOTE + INSTRUCTIONS FIX — v32
   ===================== */

/* Keep the instructions PNG fully inside the screen: no left/right or up/down scrolling */
.instructions-dialog{
  max-width:100vw !important;
  max-height:100vh !important;
  overflow:hidden !important;
}

.instructions-dialog::backdrop{
  background:rgba(14,22,19,.35);
  backdrop-filter:blur(6px);
}

.instructions-modal{
  width:min(94vw,760px) !important;
  max-width:760px !important;
  max-height:88vh !important;
  margin:auto !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  border-radius:0 !important;
  overflow:hidden !important;
  display:flex;
  align-items:center;
  justify-content:center;
}

.instructions-image{
  display:block;
  width:100%;
  max-width:100%;
  height:auto;
  max-height:88vh;
  object-fit:contain;
  margin:0 auto;
  background:transparent !important;
  border-radius:0 !important;
}

.instructions-close{
  position:fixed !important;
  top:18px !important;
  right:18px !important;
  width:46px !important;
  height:46px !important;
  border:0 !important;
  background:transparent !important;
  color:var(--green);
  font-size:46px !important;
  line-height:1 !important;
  cursor:pointer;
  z-index:999;
}

/* Make the invisible send-note hotspot definitely clickable on guest page */
body:not(.bride-page) .note-form{
  pointer-events:auto !important;
  z-index:30 !important;
}

body:not(.bride-page) .note-textarea{
  pointer-events:auto !important;
  z-index:31 !important;
}

body:not(.bride-page) .note-send-hotspot{
  top:25px !important;
  left:160px !important;
  width:270px !important;
  height:50px !important;

  pointer-events:auto !important;
  z-index:40 !important;
  cursor:pointer !important;
}
/* Bride received notes: hearts resize by note length, and note/name fonts are swapped */
body.bride-page .bride-notes-wall{
  top:505px;
  left:120px;
  width:840px;
  height:520px;
  z-index:24;
  display:flex;
  flex-wrap:wrap;
  align-content:flex-start;
  justify-content:center;
  gap:26px;
  overflow:visible;
  pointer-events:none;
}

body.bride-page .bride-note-card{
  position:relative;
  width:max-content;
  background:transparent !important;
  box-shadow:none !important;
  border-radius:0 !important;
  color:#0f4a31;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  transform:rotate(-4deg);
  --heart-size:330px;
}

body.bride-page .bride-note-card.note-size-short{
  min-width:235px;
  max-width:330px;
  min-height:205px;
  padding:62px 54px 52px;
  --heart-size:320px;
}

body.bride-page .bride-note-card.note-size-medium{
  min-width:300px;
  max-width:430px;
  min-height:255px;
  padding:78px 66px 64px;
  --heart-size:405px;
}

body.bride-page .bride-note-card.note-size-long{
  min-width:365px;
  max-width:530px;
  min-height:315px;
  padding:96px 76px 78px;
  --heart-size:500px;
}

body.bride-page .bride-note-card.note-size-extra{
  min-width:440px;
  max-width:640px;
  min-height:385px;
  padding:118px 90px 96px;
  --heart-size:620px;
}

body.bride-page .bride-note-card::before{
  content:"♥";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  z-index:-1;
  color:#ffd6e3;
  opacity:.28;
  font-family:Georgia, serif;
  font-size:var(--heart-size);
  line-height:1;
  text-shadow:0 10px 24px rgba(6,37,22,.08);
}

body.bride-page .bride-note-card:nth-child(even){
  transform:rotate(4deg);
}

body.bride-page .bride-note-card:nth-child(3n){
  transform:rotate(-1deg);
}

/* swapped: note gets the previous guest-name font */
body.bride-page .bride-note-text{
  order:1;
  margin:0 0 12px;
  max-width:100%;
  font-family:"Josefin Sans", sans-serif !important;
  text-transform:uppercase;
  letter-spacing:.07em;
  font-size:18px;
  line-height:1.18;
  font-weight:700;
  color:#0f4a31;
}

/* swapped: guest name gets the previous note font */
body.bride-page .bride-note-name{
  order:2;
  margin:0;
  font-family:"Borel", cursive !important;
  text-transform:none;
  letter-spacing:0;
  font-size:25px;
  line-height:1.05;
  font-weight:400;
  color:#0f4a31;
}

body.bride-page .bride-note-card.note-size-long .bride-note-text,
body.bride-page .bride-note-card.note-size-extra .bride-note-text{
  font-size:17px;
  line-height:1.14;
}

body.bride-page .bride-note-card.note-size-extra .bride-note-name{
  font-size:23px;
}


/* =====================
   BRIDE DYNAMIC RECTANGLE NOTES — v33
   ===================== */

/* Area where bride receives guest notes */
body.bride-page .bride-notes-wall{
  top:505px;
  left:105px;
  width:870px;
  height:455px;
  z-index:24;

  display:flex;
  flex-wrap:wrap;
  align-content:flex-start;
  justify-content:center;
  gap:8px 10px;

  overflow:hidden;
  pointer-events:none;
}

/* Base rectangle style */
body.bride-page .bride-note-card{
  position:relative;
  width:auto;
  min-width:120px;
  max-width:430px;
  min-height:58px;
  padding:10px 13px 9px;

  background:rgba(255,214,227,.42) !important;
  border:1px solid rgba(255,214,227,.56);
  border-radius:18px !important;
  box-shadow:0 8px 18px rgba(6,37,22,.06) !important;
  clip-path:none !important;

  color:#0f4a31;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;

  transform:rotate(-1deg);
}

/* remove old heart completely */
body.bride-page .bride-note-card::before{
  display:none !important;
  content:none !important;
}

body.bride-page .bride-note-card:nth-child(even){
  transform:rotate(1deg);
}

body.bride-page .bride-note-card:nth-child(3n){
  transform:rotate(-.4deg);
}

/* Extra short note = small rectangle */
body.bride-page .bride-note-card.note-rect-xs{
  width:auto;
  min-width:118px;
  max-width:165px;
  min-height:56px;
  padding:9px 12px 8px;
}

/* Short note */
body.bride-page .bride-note-card.note-rect-sm{
  width:auto;
  min-width:155px;
  max-width:225px;
  min-height:68px;
  padding:11px 14px 10px;
}

/* Medium note */
body.bride-page .bride-note-card.note-rect-md{
  width:auto;
  min-width:220px;
  max-width:315px;
  min-height:88px;
  padding:14px 17px 13px;
}

/* Long note */
body.bride-page .bride-note-card.note-rect-lg{
  width:auto;
  min-width:310px;
  max-width:420px;
  min-height:118px;
  padding:18px 22px 16px;
}

/* Very long note */
body.bride-page .bride-note-card.note-rect-xl{
  width:auto;
  min-width:405px;
  max-width:560px;
  min-height:150px;
  padding:22px 26px 20px;
}

/* Note text uses guest-name style */
body.bride-page .bride-note-text{
  order:1;
  margin:0 0 5px;
  max-width:100%;

  font-family:"Josefin Sans", sans-serif !important;
  text-transform:uppercase;
  letter-spacing:.07em;
  font-size:12px;
  line-height:1.15;
  font-weight:700;
  color:#0f4a31;
}

/* Guest name uses note/handwritten style */
body.bride-page .bride-note-name{
  order:2;
  margin:0;

  font-family:"Borel", cursive !important;
  text-transform:none;
  letter-spacing:0;
  font-size:18px;
  line-height:1;
  font-weight:400;
  color:#0f4a31;
}

/* Let text breathe more in bigger rectangles */
body.bride-page .bride-note-card.note-rect-md .bride-note-text{
  font-size:12.5px;
}

body.bride-page .bride-note-card.note-rect-lg .bride-note-text,
body.bride-page .bride-note-card.note-rect-xl .bride-note-text{
  font-size:13px;
  line-height:1.18;
}

body.bride-page .bride-note-card.note-rect-lg .bride-note-name,
body.bride-page .bride-note-card.note-rect-xl .bride-note-name{
  font-size:19px;
}

/* If many notes fill the wall, everything compresses slightly to fit */
body.bride-page .bride-notes-wall.notes-many{
  gap:6px 7px;
}

body.bride-page .bride-notes-wall.notes-many .bride-note-card{
  transform:scale(.88) rotate(-.6deg);
  transform-origin:center;
}

body.bride-page .bride-notes-wall.notes-many .bride-note-card:nth-child(even){
  transform:scale(.88) rotate(.6deg);
}

body.bride-page .bride-notes-wall.notes-full{
  gap:4px 5px;
}

body.bride-page .bride-notes-wall.notes-full .bride-note-card{
  transform:scale(.74) rotate(-.4deg);
  transform-origin:center;
}

body.bride-page .bride-notes-wall.notes-full .bride-note-card:nth-child(even){
  transform:scale(.74) rotate(.4deg);
}


/* =====================
   FINAL SMALL FIXES — v34
   ===================== */

/* Downward hero arrows: lower, clearer, a little longer */
.scroll-hint{
  top:2050px !important;
  font-size:78px !important;
  animation:scrollHintShow 22s ease forwards !important;
}

@keyframes scrollHintShow{
  0%{ opacity:0; }
  8%{ opacity:1; }
  90%{ opacity:1; }
  100%{ opacity:0; }
}

@keyframes scrollHintMove{
  0%,100%{ transform:translateX(0); }
  50%{ transform:translateX(24px); }
}

/* Back-to-top: truly fixed on the phone screen, visible throughout the whole page */
.back-to-top{
  position:fixed !important;
  right:22px !important;
  bottom:24px !important;
  z-index:99999 !important;

  width:72px !important;
  height:72px !important;
  border-radius:999px !important;

  border:1px solid rgba(4,63,47,.22) !important;
  background:rgba(255,248,238,.84) !important;
  backdrop-filter:blur(8px);

  color:var(--green) !important;
  font-family:"Josefin Sans",sans-serif !important;
  font-size:54px !important;
  line-height:72px !important;
  text-align:center !important;
  padding:0 !important;

  cursor:pointer !important;
  opacity:.94 !important;
}

/* Bride received notes: larger dynamic rectangles, bigger notes, smaller names */
body.bride-page .bride-notes-wall{
  top:505px;
  left:95px;
  width:890px;
  height:455px;
  gap:7px 8px;
}

/* Base rectangle */
body.bride-page .bride-note-card{
  min-width:170px;
  min-height:78px;
  padding:16px 20px 14px;
  background:rgba(255, 214, 227, 0.814) !important;
  border:1px solid rgba(255,214,227,.58) !important;
  border-radius:20px !important;
}

/* Extra short note = still visible but compact */
body.bride-page .bride-note-card.note-rect-xs{
  min-width:155px;
  max-width:225px;
  min-height:74px;
  padding:13px 17px 12px;
}

/* Short note */
body.bride-page .bride-note-card.note-rect-sm{
  min-width:205px;
  max-width:300px;
  min-height:92px;
  padding:16px 20px 14px;
}

/* Medium note */
body.bride-page .bride-note-card.note-rect-md{
  min-width:280px;
  max-width:390px;
  min-height:120px;
  padding:19px 24px 17px;
}

/* Long note */
body.bride-page .bride-note-card.note-rect-lg{
  min-width:390px;
  max-width:530px;
  min-height:155px;
  padding:24px 30px 22px;
}

/* Very long note */
body.bride-page .bride-note-card.note-rect-xl{
  min-width:490px;
  max-width:690px;
  min-height:200px;
  padding:30px 36px 28px;
}

/* Note itself bigger */
body.bride-page .bride-note-text{
  font-size:15.5px !important;
  line-height:1.22 !important;
}

/* Guest name smaller */
body.bride-page .bride-note-name{
  font-size:13px !important;
  line-height:1 !important;
}

/* Bigger cards can use slightly larger note text */
body.bride-page .bride-note-card.note-rect-md .bride-note-text{
  font-size:16px !important;
}

body.bride-page .bride-note-card.note-rect-lg .bride-note-text,
body.bride-page .bride-note-card.note-rect-xl .bride-note-text{
  font-size:16.5px !important;
}

/* When many notes exist, compress but keep readability */
body.bride-page .bride-notes-wall.notes-many .bride-note-card{
  transform:scale(.84) rotate(-.5deg);
  transform-origin:center;
}

body.bride-page .bride-notes-wall.notes-many .bride-note-card:nth-child(even){
  transform:scale(.84) rotate(.5deg);
}

body.bride-page .bride-notes-wall.notes-full .bride-note-card{
  transform:scale(.68) rotate(-.3deg);
  transform-origin:center;
}

body.bride-page .bride-notes-wall.notes-full .bride-note-card:nth-child(even){
  transform:scale(.68) rotate(.3deg);
}


/* =====================
   IMMEDIATE UI FIXES — v35
   ===================== */

/* Only one downward arrow, slightly lower/visible */
.scroll-hint{
  top:1700px !important;
  font-size:82px !important;
  gap:0 !important;
  animation:scrollHintShow 18s ease forwards !important;
}

.scroll-hint span:nth-child(2){
  display:none !important;
}

/* Floating back-to-top: green arrow only, no circle */
.back-to-top{
  position:fixed !important;
  right:22px !important;
  bottom:24px !important;
  z-index:999999 !important;

  width:auto !important;
  height:auto !important;
  min-width:0 !important;
  min-height:0 !important;

  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;

  color:var(--green) !important;
  font-family:"Josefin Sans", sans-serif !important;
  font-size:38px !important;
  line-height:1 !important;
  font-weight:700 !important;
  text-align:center !important;
  padding:0 !important;
  margin:0 !important;

  cursor:pointer !important;
  opacity:.94 !important;
  appearance:none !important;
  -webkit-appearance:none !important;
}

/* Move location text slightly left — works even with translateX centering */
.location-tap{
  left:44% !important;
}

/* If you need only Shalaih lower/higher later, change this value */
.location-house-number{
  display:block !important;
  transform:translateY(1200px) !important;
}

/* Bride received note board: bigger note text */
body.bride-page .bride-note-text{
  font-size:38px !important;
  line-height:1.24 !important;
}

body.bride-page .bride-note-card.note-rect-md .bride-note-text{
  font-size:18.5px !important;
}

body.bride-page .bride-note-card.note-rect-lg .bride-note-text,
body.bride-page .bride-note-card.note-rect-xl .bride-note-text{
  font-size:19px !important;
  line-height:1.25 !important;
}

/* Keep guest names smaller */
body.bride-page .bride-note-name{
  font-size:21px !important;
  line-height:1 !important;
}

/* Center “Share Memories” title and keep both side dashes on the same line */
.capture-title{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:18px !important;
  width:100% !important;
  white-space:nowrap !important;
  text-align:center !important;
}

.capture-title::before,
.capture-title::after{
  content:"" !important;
  display:block !important;
  flex:0 0 78px !important;
  width:78px !important;
  height:1px !important;
  margin:0 !important;
  background:rgba(239,127,165,.55) !important;
}

/* Guest's previously sent floating notes: start higher, narrower, slightly left */
body:not(.bride-page) .my-notes-wall{
  top:920px !important;
  left:110px !important;
  width:630px !important;
}

body:not(.bride-page) .my-notes-list{
  min-height:80px !important;
}

body:not(.bride-page) .my-note-card{
  max-width:590px !important;
  margin:5px !important;
  padding:10px 12px !important;
  font-size:27px !important;
}


.back-to-top{
  position:fixed !important;
  right:5px !important;
  bottom:10px !important;
  z-index:999999 !important;

  width:70px !important;
  height:70px !important;

  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  border-radius:0 !important;
  backdrop-filter:none !important;

  color:var(--green) !important;
  font-family:Arial, sans-serif !important;
  font-size:34px !important;
  line-height:70px !important;

  text-align:center !important;
  overflow:visible !important;
  padding:0 !important;
  margin:0 !important;

  cursor:pointer !important;
  opacity:.95 !important;
}



body.bride-page .bride-notes-wall{
  top:505px !important;
  left:95px !important;
  width:890px !important;
  height:455px !important;

  display:flex !important;
  flex-wrap:wrap !important;
  align-content:flex-start !important;
  justify-content:center !important;
  gap:10px 12px !important;

  overflow:hidden !important;
  pointer-events:none !important;
}

/* each card now naturally grows/shrinks with text */
body.bride-page .bride-note-card{
  position:relative !important;

  width:auto !important;
  min-width:0 !important;
  max-width:420px !important;
  min-height:0 !important;

  padding:0 !important;
  margin:0 !important;

  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  border-radius:0 !important;
  clip-path:none !important;

  display:inline-flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;

  text-align:center !important;
  transform:rotate(-1deg) !important;
}

/* remove old heart/rectangle */
body.bride-page .bride-note-card::before{
  display:none !important;
  content:none !important;
}

body.bride-page .bride-note-card:nth-child(even){
  transform:rotate(1deg) !important;
}

body.bride-page .bride-note-card:nth-child(3n){
  transform:rotate(-.4deg) !important;
}

/* background hugs the note text */
body.bride-page .bride-note-text{
  order:1 !important;

  display:inline-block !important;
  width:auto !important;
  max-width:360px !important;

  margin:0 0 3px !important;
  padding:10px 14px 8px !important;

  background:rgba(255,214,227,.52) !important;
  border:1px solid rgba(255,214,227,.60) !important;
  border-radius:16px !important;
  box-shadow:0 8px 18px rgba(6,37,22,.05) !important;

  font-family:"Josefin Sans", sans-serif !important;
  text-transform:uppercase !important;
  letter-spacing:.07em !important;
  font-size:18px !important;
  line-height:1.22 !important;
  font-weight:700 !important;
  color:#0f4a31 !important;
}

/* name below, smaller */
body.bride-page .bride-note-name{
  order:2 !important;
  margin:0 !important;

  font-family:"Borel", cursive !important;
  text-transform:none !important;
  letter-spacing:0 !important;
  font-size:12px !important;
  line-height:1 !important;
  font-weight:400 !important;
  color:#0f4a31 !important;
}

/* bigger notes get more room, but still hug the text */
body.bride-page .bride-note-card.note-rect-md .bride-note-text{
  max-width:420px !important;
}

body.bride-page .bride-note-card.note-rect-lg .bride-note-text,
body.bride-page .bride-note-card.note-rect-xl .bride-note-text{
  max-width:520px !important;
  padding:13px 18px 11px !important;
}

/* Bride received notes — name inside same background */
body.bride-page .bride-note-card{
  width:auto !important;
  min-width:0 !important;
  max-width:520px !important;
  min-height:0 !important;

  padding:12px 16px 10px !important;

  background:rgba(255,214,227,.52) !important;
  border:1px solid rgba(255,214,227,.60) !important;
  border-radius:16px !important;
  box-shadow:0 8px 18px rgba(6,37,22,.05) !important;

  display:inline-flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
}

/* remove background from only the note text */
body.bride-page .bride-note-text{
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;

  margin:0 0 5px !important;
  max-width:480px !important;

  font-size:27px !important;
  line-height:1.22 !important;
}

/* name is now inside same rectangle */
body.bride-page .bride-note-name{
  margin:0 !important;
  font-size:12px !important;
  line-height:1 !important;
}