/* ═══════════════════════════════════════════════════════════════
   Digital Love Gift — Premium Stylesheet v3
   Aesthetic: Soft luxury editorial — blush, ivory, deep rose
   Fonts: Cormorant Garamond (display) + DM Sans (body)
═══════════════════════════════════════════════════════════════ */

:root {
  --blush:       #f5c6d0;
  --blush-light: #fdf0f3;
  --rose:        #c96a7a;
  --rose-deep:   #a0485a;
  --ivory:       #fffaf8;
  --parchment:   #fef5ed;
  --text:        #2d1e25;
  --text-soft:   #7a5560;
  --text-muted:  #b08090;
  --border:      #ead8dc;
  --white:       #ffffff;
  --shadow:      0 4px 30px rgba(169,80,100,.10);
  --shadow-lg:   0 8px 50px rgba(169,80,100,.15);
  --radius:      16px;
  --radius-sm:   10px;
  --max-width:   720px;
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-body:   'DM Sans', system-ui, sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--ivory);color:var(--text);line-height:1.7;min-height:100vh;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:var(--font-body);border:none;background:none}

/* ── Animations ─────────────────────────────────────────────── */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes heartPop{0%{transform:scale(1)}50%{transform:scale(1.25)}100%{transform:scale(1)}}
@keyframes loadingFill{from{width:0%}to{width:95%}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(30px,-20px) scale(1.05)}}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes vinylSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
@keyframes lockShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
@keyframes heartUnlock{0%{transform:scale(1)}40%{transform:scale(1.15)}70%{transform:scale(.95)}100%{transform:scale(1)}}
@keyframes flapOpen{0%{transform:rotateX(0deg)}100%{transform:rotateX(-180deg)}}
@keyframes letterRise{0%{transform:translateY(30px);opacity:0}100%{transform:translateY(-20px);opacity:1}}
@keyframes envDissolve{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.15)}}

.fade-in        {animation:fadeUp .7s ease both}
.fade-in-delay  {animation:fadeUp .7s .2s ease both}
.fade-in-delay-2{animation:fadeUp .7s .4s ease both}
.fade-in-delay-3{animation:fadeUp .7s .6s ease both}
.hidden         {display:none!important}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:14px 32px;background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;border-radius:50px;font-size:1rem;font-weight:500;letter-spacing:.02em;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(169,80,100,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(169,80,100,.45)}
.btn-large{padding:17px 40px;font-size:1.05rem}
.btn-full{width:100%;justify-content:center}
.footer{text-align:center;padding:40px 20px;color:var(--text-muted);font-size:.85rem}

/* ═══════════════════════════════════════════════════════════════
   LANDING PAGE
═══════════════════════════════════════════════════════════════ */
.landing-page{background:var(--ivory)}
.landing-main{position:relative;z-index:1;max-width:var(--max-width);margin:0 auto;padding:60px 24px 0}
.hero{text-align:center;padding:60px 0 80px}
.hero-badge{display:inline-block;padding:6px 18px;border-radius:50px;border:1px solid var(--blush);color:var(--rose);font-size:.82rem;letter-spacing:.05em;margin-bottom:28px;background:var(--white)}
.hero-title{font-family:var(--font-display);font-size:clamp(2.6rem,7vw,4.5rem);font-weight:300;line-height:1.18;color:var(--text);margin-bottom:24px}
.hero-title em{font-style:italic;color:var(--rose)}
.hero-sub{color:var(--text-soft);font-size:1.05rem;line-height:1.8;margin-bottom:40px}
.how-it-works{padding:60px 0;text-align:center}
.section-title{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:40px}
.steps{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap;justify-content:center}
.step{flex:1;min-width:180px;max-width:200px;padding:24px 16px;background:var(--white);border-radius:var(--radius);border:1px solid var(--border)}
.step-icon{font-size:2rem;margin-bottom:12px}
.step h3{font-size:.95rem;font-weight:500;margin-bottom:8px}
.step p{font-size:.85rem;color:var(--text-soft);line-height:1.6}
.step-divider{color:var(--text-muted);font-size:1.5rem;padding-top:32px;flex-shrink:0}
@media(max-width:600px){.step-divider{display:none}}
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;padding:20px 0 60px}
.feature-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:24px 20px;text-align:center}
.feature-icon{font-size:1.8rem;margin-bottom:10px;display:block}
.feature-card h4{font-size:.9rem;font-weight:500;margin-bottom:6px}
.feature-card p{font-size:.82rem;color:var(--text-soft);line-height:1.6}
.cta{text-align:center;padding:60px 24px;background:linear-gradient(135deg,#fff0f3,#fdf0f3);border-radius:var(--radius);border:1px solid var(--blush);margin-bottom:60px}
.cta h2{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:28px}

/* ═══════════════════════════════════════════════════════════════
   CREATE PAGE
═══════════════════════════════════════════════════════════════ */
.create-page{background:var(--blush-light)}
.create-main{max-width:620px;margin:0 auto;padding:40px 24px 80px}
.back-link{display:inline-block;color:var(--text-soft);font-size:.88rem;margin-bottom:28px;transition:color .2s}
.back-link:hover{color:var(--rose)}
.create-header{text-align:center;margin-bottom:40px}
.create-header h1{font-family:var(--font-display);font-size:clamp(2rem,6vw,3rem);font-weight:300;margin-bottom:10px}
.create-header em{color:var(--rose);font-style:italic}
.create-header p{color:var(--text-soft);font-size:.95rem}
.gift-form{display:flex;flex-direction:column;gap:28px}
.form-section{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:28px 24px;box-shadow:var(--shadow)}
.form-section-label{display:flex;align-items:center;gap:12px;font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);margin-bottom:20px}
.form-section-num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:var(--blush);color:var(--rose-deep);font-size:.72rem;font-weight:600;flex-shrink:0}
.form-section-hint{font-size:.85rem;color:var(--text-muted);margin-bottom:16px}
.optional-tag{font-size:.7rem;color:var(--text-muted);font-style:italic;font-weight:400;text-transform:none;letter-spacing:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;gap:6px;margin-top:12px}
.form-group:first-of-type{margin-top:0}
label{font-size:.82rem;font-weight:500;color:var(--text);letter-spacing:.01em}
input[type="text"],input[type="url"],input[type="date"],input[type="password"],select,textarea{padding:11px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.92rem;color:var(--text);background:var(--white);transition:border-color .2s,box-shadow .2s;outline:none;-webkit-appearance:none}
input:focus,select:focus,textarea:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(201,106,122,.15)}
input::placeholder{color:var(--text-muted)}
select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23b08090' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.upload-area{position:relative;border:2px dashed var(--blush);border-radius:var(--radius);padding:32px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--blush-light)}
.upload-area:hover,.upload-area.drag-over{border-color:var(--rose);background:#fde8ed}
.file-input{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}
.upload-icon{font-size:2rem;display:block;margin-bottom:8px}
.upload-prompt p{font-size:.9rem;color:var(--text-soft);margin-bottom:4px}
.upload-note{font-size:.75rem;color:var(--text-muted)}
.image-previews{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px;margin-top:12px}
.preview-item{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:1;background:var(--blush-light)}
.preview-item img{width:100%;height:100%;object-fit:cover}
.preview-remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;font-size:.75rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
.preview-remove:hover{background:var(--rose-deep)}
.form-error{padding:14px 18px;background:#fff0f0;border:1px solid #f5c6c6;border-radius:var(--radius-sm);color:#c0392b;font-size:.88rem}
.form-note{text-align:center;font-size:.8rem;color:var(--text-muted);margin-top:-8px}
.input-hint{font-size:.75rem;color:var(--text-muted);margin-top:4px;display:block}
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.toggle-label{display:flex;flex-direction:column;gap:3px}
.toggle-label span:first-child{font-size:.9rem;font-weight:500}
.toggle-hint{font-size:.78rem;color:var(--text-muted)}
.toggle{position:relative;width:46px;height:26px;flex-shrink:0;cursor:pointer}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:26px;transition:background .3s}
.toggle-slider::before{content:'';position:absolute;width:20px;height:20px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 1px 4px rgba(0,0,0,.15)}
.toggle input:checked+.toggle-slider{background:var(--rose)}
.toggle input:checked+.toggle-slider::before{transform:translateX(20px)}
.timeline-entry+.timeline-entry{margin-top:4px}

/* Loading overlay */
.loading-overlay{position:fixed;inset:0;background:rgba(255,245,248,.95);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:999}
.loading-card{text-align:center;padding:48px 40px;max-width:340px}
.loading-hearts{display:flex;justify-content:center;gap:12px;font-size:2rem;margin-bottom:24px}
.loading-hearts span:nth-child(1){animation:heartPop 1.2s 0s ease-in-out infinite}
.loading-hearts span:nth-child(2){animation:heartPop 1.2s .3s ease-in-out infinite}
.loading-hearts span:nth-child(3){animation:heartPop 1.2s .6s ease-in-out infinite}
.loading-card h2{font-family:var(--font-display);font-size:1.7rem;font-weight:400;margin-bottom:10px}
.loading-card p{color:var(--text-soft);font-size:.92rem;margin-bottom:24px}
.loading-bar{width:100%;height:3px;background:var(--blush);border-radius:4px;overflow:hidden}
.loading-fill{height:100%;background:linear-gradient(90deg,var(--rose),var(--rose-deep));border-radius:4px;animation:loadingFill 20s ease-out forwards}

/* ═══════════════════════════════════════════════════════════════
   GIFT PAGE
═══════════════════════════════════════════════════════════════ */
.gift-page{background:var(--parchment);min-height:100vh}

/* Occasion background canvas */

/* Confetti canvas */
.confetti-canvas{position:fixed;inset:0;pointer-events:none;z-index:200;display:none}

/* Gift loading/error */
.gift-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;position:relative;z-index:10}
.gift-loading p{color:var(--text-soft);animation:pulse 1.5s ease-in-out infinite}
.gift-error{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:40px 24px;position:relative;z-index:10}
.gift-error-card{text-align:center;background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:48px 40px;max-width:380px}
.gift-error-card span{font-size:3rem;display:block;margin-bottom:16px}
.gift-error-card h2{font-family:var(--font-display);font-size:1.6rem;margin-bottom:10px}
.gift-error-card p{color:var(--text-soft);margin-bottom:24px;font-size:.9rem}

/* ── Heart Lock Screen ───────────────────────────────────────── */
.lock-screen{position:fixed;inset:0;background:linear-gradient(160deg,#fff5f8,#fdf0f3,#fff8fc);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}
.lock-card{text-align:center;background:rgba(255,255,255,.85);backdrop-filter:blur(20px);border:1px solid var(--blush);border-radius:24px;padding:48px 40px 40px;max-width:420px;width:100%;box-shadow:0 20px 80px rgba(169,80,100,.18)}
.heart-lock-wrap{margin-bottom:20px}
.heart-lock{width:120px;height:110px;filter:drop-shadow(0 4px 20px rgba(201,106,122,.35));transition:filter .4s}
.heart-lock.unlocked{filter:drop-shadow(0 4px 30px rgba(201,106,122,.6))}
.heart-lock.shake{animation:lockShake .4s ease}
#heart-path{transition:fill .5s}
.heart-lock.unlocked #heart-path{fill:var(--rose)}
#lock-shackle{transition:transform .5s,stroke .5s;transform-origin:60px 52px}
.heart-lock.unlocked #lock-shackle{transform:rotate(-30deg) translateY(-6px);stroke:var(--rose)}
.lock-shake-hint{font-size:.78rem;color:var(--text-muted);margin-top:8px}
.lock-title{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:8px;color:var(--text)}
.lock-sub{color:var(--text-soft);font-size:.93rem;margin-bottom:20px}
.lock-suggestions{margin-bottom:20px;background:var(--blush-light);border-radius:12px;padding:14px 16px}
.suggestions-label{font-size:.73rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:8px;font-weight:500}
.suggestions-chips{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.chip{background:var(--white);border:1px solid var(--blush);border-radius:50px;padding:4px 12px;font-size:.78rem;color:var(--text-soft)}
.lock-input-wrap{display:flex;flex-direction:column;gap:10px}
.lock-input{padding:14px 20px;border:1.5px solid var(--border);border-radius:50px;font-family:var(--font-body);font-size:1rem;text-align:center;outline:none;transition:border-color .2s,box-shadow .2s;background:var(--blush-light);color:var(--text)}
.lock-input:focus{border-color:var(--rose);box-shadow:0 0 0 3px rgba(201,106,122,.15)}
.lock-btn{padding:14px 28px;background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;border-radius:50px;font-size:1rem;font-weight:500;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px rgba(169,80,100,.35);cursor:pointer;border:none}
.lock-btn:hover{transform:translateY(-2px)}
.lock-error{color:var(--rose-deep);font-size:.88rem;margin-top:10px;animation:fadeUp .3s ease}

/* ── Envelope Screen ─────────────────────────────────────────── */
.envelope-screen{position:fixed;inset:0;background:var(--parchment);display:flex;align-items:center;justify-content:center;flex-direction:column;z-index:90;cursor:pointer}
.env-wrap{text-align:center;user-select:none}
.env{width:240px;height:170px;position:relative;margin:0 auto 20px;cursor:pointer;perspective:800px}
.env-back,.env-left,.env-right,.env-bottom,.env-flap{position:absolute}
.env-back{inset:0;background:linear-gradient(160deg,#fff0f3,#fde8ed);border-radius:12px;border:2px solid var(--blush);box-shadow:0 10px 50px rgba(169,80,100,.25)}
.env-flap{top:0;left:0;right:0;height:52%;clip-path:polygon(0 0,100% 0,50% 100%);background:linear-gradient(170deg,#f9d0d8,#f5c6d0);border-radius:12px 12px 0 0;transform-origin:top center;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.4,0,.2,1);z-index:4;border:2px solid var(--blush);border-bottom:none}
.env-left{top:52%;left:0;bottom:0;width:50%;background:linear-gradient(135deg,#fde8ed,#f9d0d8);clip-path:polygon(0 0,100% 0,0 100%);border-radius:0 0 0 12px}
.env-right{top:52%;right:0;bottom:0;width:50%;background:linear-gradient(225deg,#fde8ed,#f9d0d8);clip-path:polygon(0 0,100% 0,100% 100%);border-radius:0 0 12px 0}
.env-bottom{bottom:0;left:0;right:0;height:52%;background:linear-gradient(to top,#fde8ed,transparent);border-radius:0 0 12px 12px}
.env-letter{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3rem;z-index:3;transition:transform .7s .1s ease,opacity .5s .1s ease}
.env.opening .env-flap{transform:rotateX(-180deg)}
.env.opening .env-letter{transform:translateY(-40px) scale(1.2);opacity:0}
.env-hint{color:var(--text-soft);font-size:.9rem;animation:pulse 2s ease-in-out infinite;margin-top:8px}

/* ── Gift content ─────────────────────────────────────────────── */
.gift-content{position:relative;z-index:1;max-width:var(--max-width);margin:0 auto;padding:0 24px 80px}
.gift-hero{text-align:center;padding:80px 0 50px}
.gift-occasion{display:inline-block;padding:5px 16px;border-radius:50px;background:var(--blush);color:var(--rose-deep);font-size:.78rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:20px}
.gift-title{font-family:var(--font-display);font-size:clamp(2.2rem,7vw,4rem);font-weight:300;font-style:italic;color:var(--text);line-height:1.22;margin-bottom:16px}
.gift-subtitle{font-family:var(--font-display);font-style:italic;color:var(--text-soft);font-size:1.1rem;margin-bottom:16px}
.gift-recipient{color:var(--text-soft);font-size:1rem;margin-bottom:20px}
.gift-recipient span{color:var(--rose);font-weight:500}
.gift-date{color:var(--text-muted);font-size:.82rem}
.days-counter{margin:24px auto 0;display:inline-flex;flex-direction:column;align-items:center;background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;border-radius:20px;padding:16px 36px;box-shadow:0 4px 24px rgba(169,80,100,.4)}
.days-number{font-family:var(--font-display);font-size:3rem;font-weight:600;line-height:1}
.days-label{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;opacity:.85}

/* ── Sections ─────────────────────────────────────────────────── */
.gift-section{margin:60px 0;text-align:center}
.section-ornament{font-size:1.8rem;margin-bottom:12px}
.section-heading{font-family:var(--font-display);font-size:1.9rem;font-weight:400;color:var(--text);margin-bottom:28px}
.fade-scroll{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.fade-scroll.visible{opacity:1;transform:translateY(0)}

/* ── Magazine Collage ────────────────────────────────────────── */
.magazine-collage{display:grid;gap:10px;max-width:660px;margin:0 auto}
/* 1 photo */
.magazine-collage.photos-1{grid-template-columns:1fr}
.magazine-collage.photos-1 .col-item{height:400px}
/* 2 photos */
.magazine-collage.photos-2{grid-template-columns:1fr 1fr}
.magazine-collage.photos-2 .col-item{height:320px}
/* 3 photos: big left, 2 right stacked */
.magazine-collage.photos-3{grid-template-columns:1.4fr 1fr;grid-template-rows:200px 200px}
.magazine-collage.photos-3 .col-item:first-child{grid-row:1/3;height:410px}
.magazine-collage.photos-3 .col-item:not(:first-child){height:200px}
/* 4 photos: big top, 3 bottom */
.magazine-collage.photos-4{grid-template-columns:1fr 1fr 1fr;grid-template-rows:280px 180px}
.magazine-collage.photos-4 .col-item:first-child{grid-column:1/4;height:280px}
.magazine-collage.photos-4 .col-item:not(:first-child){height:180px}
/* 5 photos: big left top + 4 grid */
.magazine-collage.photos-5{grid-template-columns:1.3fr 1fr 1fr;grid-template-rows:220px 190px}
.magazine-collage.photos-5 .col-item:first-child{grid-row:1/3;height:420px}
.magazine-collage.photos-5 .col-item:not(:first-child){height:205px}

.col-item{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px rgba(45,30,37,.15)}
.col-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.col-item:hover img{transform:scale(1.04)}
.col-caption{position:absolute;bottom:0;left:0;right:0;padding:16px 18px;background:linear-gradient(to top,rgba(45,30,37,.82),transparent);color:#fff;font-family:var(--font-display);font-style:italic;font-size:.9rem;line-height:1.4;opacity:0;transition:opacity .3s ease}
.col-item:hover .col-caption{opacity:1}
@media(max-width:560px){
  .magazine-collage.photos-3,.magazine-collage.photos-4,.magazine-collage.photos-5{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .magazine-collage .col-item{height:160px!important;grid-column:auto!important;grid-row:auto!important}
}

/* ── Letter / Typewriter ─────────────────────────────────────── */
.gift-letter{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:36px 40px;text-align:left;box-shadow:var(--shadow);font-family:var(--font-display);font-size:1.05rem;line-height:1.9;color:var(--text);position:relative;overflow:hidden}
.gift-letter p+p{margin-top:1.2em}
.typewriter-cursor{display:inline-block;width:2px;height:1.1em;background:var(--rose);margin-left:2px;vertical-align:middle;animation:pulse .7s ease-in-out infinite}
.read-full-btn{display:block;margin:16px auto 0;padding:10px 24px;border-radius:50px;border:1.5px solid var(--blush);color:var(--rose);font-size:.88rem;background:transparent;cursor:pointer;transition:all .2s}
.read-full-btn:hover{background:var(--blush-light)}

/* ── Poem ─────────────────────────────────────────────────────── */
.gift-poem{max-width:460px;margin:0 auto;background:linear-gradient(135deg,var(--white),#fff5f8);border:1px solid var(--blush);border-radius:var(--radius);padding:36px 40px;font-family:var(--font-display);font-size:1.15rem;font-style:italic;line-height:2;color:var(--text);box-shadow:var(--shadow);white-space:pre-line;text-align:center}

/* ── Timeline ─────────────────────────────────────────────────── */
.timeline{position:relative;max-width:520px;margin:0 auto;padding:0 0 0 32px}
.timeline::before{content:'';position:absolute;left:12px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--blush),var(--rose),var(--blush));border-radius:2px}
.timeline-item{position:relative;margin-bottom:32px;text-align:left}
.timeline-item::before{content:'💗';position:absolute;left:-32px;top:2px;font-size:1.1rem}
.timeline-date{font-size:.75rem;color:var(--rose);font-weight:500;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.timeline-event{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text);margin-bottom:4px}
.timeline-note{font-size:.88rem;color:var(--text-soft);font-style:italic;line-height:1.6}

/* ── Reasons ──────────────────────────────────────────────────── */
.reasons-list{display:flex;flex-direction:column;gap:14px;max-width:500px;margin:0 auto;text-align:left}
.reason-item{display:flex;align-items:flex-start;gap:14px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px 20px;box-shadow:var(--shadow);font-size:.95rem;line-height:1.6}
.reason-num{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--blush);color:var(--rose-deep);font-size:.78rem;font-weight:600;display:flex;align-items:center;justify-content:center}

/* ── Song Card + Vinyl ───────────────────────────────────────── */
.song-card{background:linear-gradient(135deg,var(--white),#fff5f8);border:1px solid var(--blush);border-radius:var(--radius);padding:32px 36px;max-width:500px;margin:0 auto;box-shadow:var(--shadow);display:flex;gap:24px;align-items:center;text-align:left}
@media(max-width:500px){.song-card{flex-direction:column;text-align:center}}
.song-vinyl{width:90px;height:90px;flex-shrink:0;border-radius:50%;background:radial-gradient(circle at 50%,#3d2030 0%,#2d1520 30%,#c96a7a 31%,#a0485a 45%,#2d1520 46%,#3d2030 60%,#c96a7a 61%,#a0485a 75%,#2d1520 76%);box-shadow:0 4px 20px rgba(45,30,37,.35);animation:vinylSpin 4s linear infinite;display:flex;align-items:center;justify-content:center}
.vinyl-label{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#fff0f3,#fde8ed);display:flex;align-items:center;justify-content:center;font-size:.9rem;animation:vinylSpin 4s linear infinite reverse}
.song-info{flex:1}
.song-name{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--rose);margin-bottom:10px}
.song-note{color:var(--text-soft);font-size:.93rem;line-height:1.7;font-style:italic}

/* ── Final Message ───────────────────────────────────────────── */
.gift-final{text-align:center;padding:60px 20px;background:linear-gradient(135deg,#fff0f3,#fdf0f3);border-radius:var(--radius);border:1px solid var(--blush);margin:56px 0 40px}
.final-hearts{font-size:2.5rem;margin-bottom:24px}
.final-message{font-family:var(--font-display);font-size:clamp(1.3rem,4vw,1.8rem);font-weight:300;font-style:italic;color:var(--text);line-height:1.5;max-width:500px;margin:0 auto}
.final-message::before{content:open-quote;color:var(--rose);font-size:2em;line-height:0;vertical-align:-.4em}
.final-message::after{content:close-quote;color:var(--rose);font-size:2em;line-height:0;vertical-align:-.4em}

/* ── Reactions ───────────────────────────────────────────────── */
.reaction-section{text-align:center;padding:48px 24px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);margin:40px 0;box-shadow:var(--shadow)}
.reaction-title{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:20px}
.reaction-emojis{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:16px}
.reaction-btn{font-size:2rem;width:56px;height:56px;border-radius:50%;border:2px solid var(--border);background:var(--white);cursor:pointer;transition:transform .2s,border-color .2s,box-shadow .2s;display:flex;align-items:center;justify-content:center}
.reaction-btn:hover{transform:scale(1.2);border-color:var(--rose);box-shadow:0 4px 16px rgba(169,80,100,.25)}
.reaction-btn.selected{border-color:var(--rose);background:var(--blush-light);transform:scale(1.15)}
.reaction-message-wrap{max-width:400px;margin:0 auto}
.reaction-textarea{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font-body);font-size:.92rem;resize:none;outline:none;transition:border-color .2s}
.reaction-textarea:focus{border-color:var(--rose)}
.reaction-sent{padding:20px;animation:fadeUp .5s ease}
.reaction-sent-emoji{font-size:3rem;margin-bottom:8px;animation:heartPop .5s ease}
.reaction-sent p{color:var(--text-soft);font-size:.95rem}
.reactions-display{margin-top:20px;display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.reaction-pill{background:var(--blush-light);border:1px solid var(--blush);border-radius:50px;padding:6px 14px;font-size:.85rem;color:var(--text-soft)}

/* ── Share / QR ──────────────────────────────────────────────── */
.share-bar{text-align:center;padding:32px 20px}
.share-bar p{color:var(--text-soft);font-size:.88rem;margin-bottom:14px}
.share-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.share-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border-radius:50px;font-size:.9rem;font-weight:500;transition:all .2s;background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;box-shadow:0 3px 15px rgba(169,80,100,.3);cursor:pointer;border:none}
.share-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(169,80,100,.4)}
.share-btn-outline{background:var(--white);color:var(--rose);border:1.5px solid var(--blush);box-shadow:none}
.share-btn-outline:hover{background:var(--blush-light)}
.share-btn.copied{background:#27ae60;box-shadow:0 3px 15px rgba(39,174,96,.3)}
.qr-panel{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:12px;animation:fadeUp .4s ease}
.qr-panel canvas,.qr-panel img{border-radius:12px;border:4px solid var(--white);box-shadow:var(--shadow)}
.qr-hint{font-size:.8rem;color:var(--text-muted)}

/* ── YouTube embed ───────────────────────────────────────────── */
.yt-embed-wrap{max-width:500px;margin:24px auto 0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg)}
.yt-embed-wrap iframe{display:block;width:100%;aspect-ratio:16/9;border:0}

/* ═══════════════════════════════════════════════════════════════
   OCCASION COLOUR THEMES — CSS custom-property overrides
   Applied via body.theme-* classes set by gift.js
═══════════════════════════════════════════════════════════════ */
:root{
  --occ-primary:   var(--rose);
  --occ-secondary: var(--rose-deep);
  --occ-bg:        var(--parchment);
  --occ-blush:     var(--blush);
}
body.theme-birthday  { --occ-primary:#d97706; --occ-secondary:#92400e; --occ-bg:#fffcf0; --occ-blush:#fde68a }
body.theme-anniversary{ --occ-primary:#9f1239; --occ-secondary:#7f1d1d; --occ-bg:#fff1f2; --occ-blush:#fecdd3 }
body.theme-valentine { --occ-primary:#e11d48; --occ-secondary:#be185d; --occ-bg:#fff0f5; --occ-blush:#fce7f3 }
body.theme-proposal  { --occ-primary:#b45309; --occ-secondary:#78350f; --occ-bg:#fffdf5; --occ-blush:#fef3c7 }

/* Apply occasion vars to gift page elements */
.gift-page{background:var(--occ-bg)}
.gift-page .gift-occasion{background:var(--occ-blush);color:var(--occ-secondary)}
.gift-page .days-counter{background:linear-gradient(135deg,var(--occ-primary),var(--occ-secondary))}
.gift-page .reason-num{background:var(--occ-blush);color:var(--occ-secondary)}

/* Sacramento headline font on gift page */
.gift-title{font-family:'Sacramento',var(--font-display),cursive;font-style:normal;font-weight:400;font-size:clamp(2.8rem,9vw,5.5rem);line-height:1.1}
.final-message{font-family:'Sacramento',var(--font-display),cursive;font-size:clamp(1.5rem,5vw,2.2rem);font-style:normal}

/* ═══════════════════════════════════════════════════════════════
   PETAL OVERLAY — cinematic gift opening
═══════════════════════════════════════════════════════════════ */
.petal-overlay{position:fixed;inset:0;z-index:250;pointer-events:none;background:linear-gradient(160deg,#fff5f8,#fdf0f3,#fff8fc);overflow:hidden;display:flex;align-items:center;justify-content:center;transition:opacity 1s ease}
.petal-overlay.fade-out{opacity:0}
.petal-overlay-text{font-family:'Sacramento',var(--font-display),cursive;font-size:clamp(2rem,8vw,3.5rem);color:var(--rose);opacity:.6;animation:pulse 2s ease-in-out infinite;text-align:center}
.falling-petal{position:absolute;border-radius:50% 0 50% 0;animation:petalFall linear forwards;will-change:transform,opacity}
@keyframes petalFall{
  0%  {transform:translateY(-40px) rotate(0deg) scale(1);opacity:.8}
  80% {opacity:.55}
  100%{transform:translateY(110vh) rotate(720deg) scale(.8);opacity:0}
}

/* ═══════════════════════════════════════════════════════════════
   PREVIEW / LOCKED MODE (gift.html?preview=true)
═══════════════════════════════════════════════════════════════ */
.preview-mode .gift-letter{filter:blur(5px);user-select:none;pointer-events:none;transition:filter .3s}
.preview-mode .reasons-list{filter:blur(5px);user-select:none;pointer-events:none}
.preview-mode .gift-poem{filter:blur(5px);user-select:none;pointer-events:none}
.preview-lock{position:sticky;bottom:0;left:0;right:0;padding:60px 24px 32px;background:linear-gradient(to top,rgba(255,250,248,1) 55%,rgba(255,250,248,0));text-align:center;z-index:50;margin-top:-80px}
.preview-lock h3{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:8px;color:var(--text)}
.preview-lock p{color:var(--text-soft);font-size:.88rem;margin-bottom:20px}

/* PDF download button */
.pdf-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:50px;border:1.5px solid var(--blush);color:var(--rose);font-size:.88rem;font-weight:500;background:var(--white);cursor:pointer;transition:all .2s}
.pdf-btn:hover{background:var(--blush-light);border-color:var(--rose)}

/* Demo banner */
.demo-banner{position:fixed;top:0;left:0;right:0;z-index:350;background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;text-align:center;padding:11px 20px;font-size:.87rem;font-weight:500;display:flex;align-items:center;justify-content:center;gap:18px;box-shadow:0 2px 20px rgba(169,80,100,.4)}
.demo-banner a{color:#fff;text-decoration:underline;font-weight:600;white-space:nowrap}
.demo-banner-content{max-width:var(--max-width);width:100%;display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.gift-content.demo-offset{margin-top:46px}

/* ═══════════════════════════════════════════════════════════════
   LANDING PAGE — gradient background replacing emoji petals
═══════════════════════════════════════════════════════════════ */
.landing-gradient-bg{position:fixed;inset:0;background:linear-gradient(150deg,#fff5f8 0%,#fdf0f3 50%,#fff8fc 100%);z-index:0;pointer-events:none}

/* Hero CTA + social proof row */
.hero-actions{display:flex;align-items:center;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:40px}
.btn-demo{display:inline-flex;align-items:center;gap:6px;color:var(--rose);font-size:.95rem;font-weight:500;padding:12px 24px;border-radius:50px;border:1.5px solid var(--blush);transition:all .2s;background:rgba(255,255,255,.8)}
.btn-demo:hover{background:var(--white);border-color:var(--rose);transform:translateY(-1px)}
.hero-social-proof{display:flex;align-items:center;gap:28px;justify-content:center;flex-wrap:wrap}
.proof-counter{display:flex;align-items:baseline;gap:4px;color:var(--text-soft);font-size:.9rem}
.proof-number{font-family:var(--font-display);font-size:1.6rem;font-weight:600;color:var(--rose-deep);line-height:1}
.proof-stars{font-size:.83rem;color:var(--text-muted)}
.proof-stars-icons{color:#d97706;letter-spacing:-1px}

/* Testimonials */
.testimonials{padding:40px 0 60px;text-align:center}
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-top:8px}
.testimonial-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:24px 22px;text-align:left;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s}
.testimonial-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.testimonial-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.testimonial-avatar{width:48px;height:48px;border-radius:50%;border:2px solid var(--blush);flex-shrink:0}
.testimonial-name{font-weight:600;font-size:.9rem;color:var(--text)}
.testimonial-occasion{font-size:.75rem;color:var(--text-soft);margin-top:1px}
.testimonial-stars{color:#d97706;font-size:.78rem;margin-top:2px;letter-spacing:.5px}
.testimonial-quote{font-size:.875rem;line-height:1.75;color:var(--text-soft);font-style:italic}

/* Pricing */
.pricing{padding:40px 0 60px;text-align:center}
.pricing-sub{color:var(--text-soft);margin-bottom:32px;font-size:.95rem}
.pricing-card{background:var(--white);border:2px solid var(--blush);border-radius:var(--radius);padding:36px 40px;max-width:440px;margin:0 auto;box-shadow:0 8px 50px rgba(169,80,100,.15);position:relative}
.pricing-badge{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:linear-gradient(135deg,var(--rose),var(--rose-deep));color:#fff;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 18px;border-radius:50px;white-space:nowrap}
.pricing-price{margin-bottom:24px}
.price-amount{font-family:var(--font-display);font-size:4.5rem;font-weight:600;color:var(--rose-deep);line-height:1;display:inline-block}
.price-unit{font-size:.95rem;color:var(--text-muted);margin-left:6px;vertical-align:middle}
.pricing-features{list-style:none;text-align:left;margin-bottom:28px;display:flex;flex-direction:column;gap:9px}
.pricing-features li{font-size:.88rem;color:var(--text-soft);display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.pricing-note{font-size:.75rem;color:var(--text-muted);margin-top:14px}

/* ═══════════════════════════════════════════════════════════════
   PAY PAGE
═══════════════════════════════════════════════════════════════ */
.pay-page{background:var(--blush-light);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.pay-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:48px 40px;max-width:480px;width:100%;text-align:center;box-shadow:0 12px 60px rgba(169,80,100,.15)}
.pay-card h1{font-family:var(--font-display);font-size:1.6rem;font-weight:400;margin-bottom:6px}
.pay-card>p{color:var(--text-soft);font-size:.9rem;margin-bottom:0}
.pay-preview{background:var(--blush-light);border:1px solid var(--blush);border-radius:var(--radius-sm);padding:20px 22px;margin:22px 0;text-align:left}
.pay-preview-occasion{font-size:.7rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--rose);margin-bottom:6px}
.pay-preview-title{font-family:var(--font-display);font-size:1.55rem;font-weight:300;font-style:italic;color:var(--text);margin-bottom:5px;line-height:1.3}
.pay-preview-recipient{font-size:.84rem;color:var(--text-soft);margin-bottom:12px}
.pay-preview-excerpt{font-family:var(--font-display);font-size:.93rem;font-style:italic;color:var(--text-soft);line-height:1.65;border-left:2px solid var(--blush);padding-left:12px}
.pay-divider{width:36px;height:2px;background:var(--blush);margin:20px auto;border-radius:2px}
.pay-price{font-family:var(--font-display);font-size:3rem;font-weight:600;color:var(--rose-deep);line-height:1;margin-bottom:4px}
.pay-price-note{font-size:.78rem;color:var(--text-muted);margin-bottom:22px}
.pay-includes{text-align:left;margin-bottom:24px;display:flex;flex-direction:column;gap:7px;list-style:none}
.pay-includes li{font-size:.84rem;color:var(--text-soft)}
.pay-secondary{margin-top:16px;font-size:.84rem;color:var(--text-muted)}
.pay-secondary a{color:var(--rose);text-decoration:underline}
.pay-loading{color:var(--text-soft);font-size:.9rem;margin:20px 0;animation:pulse 1.5s ease-in-out infinite}

/* ═══════════════════════════════════════════════════════════════
   CREATE PAGE ENHANCEMENTS
═══════════════════════════════════════════════════════════════ */
.char-count{font-size:.72rem;color:var(--text-muted);text-align:right;margin-top:3px}
.char-count.warn{color:#d97706}
.char-count.danger{color:#e11d48}
.inspiration-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.inspiration-row label{margin:0}
.inspiration-btn{display:inline-flex;align-items:center;gap:4px;font-size:.73rem;color:var(--rose);background:none;border:none;cursor:pointer;padding:3px 8px;border-radius:50px;border:1px solid var(--blush);transition:all .15s;white-space:nowrap;flex-shrink:0}
.inspiration-btn:hover{background:var(--blush-light)}
.inspiration-example{background:var(--blush-light);border:1px solid var(--blush);border-radius:var(--radius-sm);padding:9px 13px;font-size:.81rem;color:var(--text-soft);font-style:italic;line-height:1.6;display:none;margin-top:6px}
.inspiration-example.open{display:block;animation:fadeUp .25s ease}

/* Form section scroll entrance */
.form-section{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.form-section.visible{opacity:1;transform:translateY(0)}

/* Cinematic loading overlay */
.loading-overlay{position:fixed;inset:0;background:rgba(253,240,243,.97);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:999}
.loading-card{text-align:center;padding:48px 40px;max-width:360px}
.loading-hearts{display:flex;justify-content:center;gap:16px;font-size:2.8rem;margin-bottom:28px}
.loading-hearts span:nth-child(1){animation:heartPop 1.4s 0s ease-in-out infinite}
.loading-hearts span:nth-child(2){animation:heartPop 1.4s .35s ease-in-out infinite}
.loading-hearts span:nth-child(3){animation:heartPop 1.4s .7s ease-in-out infinite}
.loading-card h2{font-family:var(--font-display);font-size:2rem;font-weight:400;margin-bottom:12px}
.loading-card p{color:var(--text-soft);font-size:.95rem;margin-bottom:28px;min-height:1.4em;transition:opacity .3s}
.loading-bar{width:100%;height:4px;background:var(--blush);border-radius:4px;overflow:hidden}
.loading-fill{height:100%;background:linear-gradient(90deg,var(--rose),var(--rose-deep),var(--rose));background-size:200% 100%;border-radius:4px;animation:loadingFill 22s ease-out forwards,shimmer 2s linear infinite}

/* ═══════════════════════════════════════════════════════════════
   MOBILE-FIRST IMPROVEMENTS
═══════════════════════════════════════════════════════════════ */
@media(max-width:640px){
  /* Landing */
  .landing-main{padding:32px 18px 0}
  .hero{padding:40px 0 56px}
  .hero-title{font-size:clamp(2.4rem,11vw,3.2rem);line-height:1.15}
  .hero-sub{font-size:.92rem;line-height:1.75}
  .hero-actions{flex-direction:column;align-items:stretch;gap:12px}
  .hero-actions .btn-primary,.hero-actions .btn-demo{width:100%;justify-content:center}
  .hero-social-proof{gap:16px}
  .testimonials-grid{grid-template-columns:1fr}
  .pricing-card{padding:32px 22px}
  .price-amount{font-size:3.5rem}
  /* Gift */
  .gift-content{padding:0 16px 60px}
  .gift-hero{padding:56px 0 36px}
  .gift-letter{padding:24px 18px;font-size:.97rem}
  .gift-poem{padding:24px 18px;font-size:1.05rem}
  .song-card{flex-direction:column;text-align:center;padding:24px 20px}
  .gift-final{padding:44px 18px}
  .share-actions{flex-direction:column;align-items:stretch}
  .share-btn{justify-content:center}
  /* Pay */
  .pay-card{padding:32px 20px}
  /* Create */
  .create-main{padding:28px 16px 60px}
  .form-section{padding:20px 16px}
  .form-section-label{font-size:.72rem}
  /* Lock */
  .lock-card{padding:36px 22px 30px}
}
@media(max-width:400px){
  .hero-title{font-size:2.2rem}
  .gift-title{font-size:2.5rem}
}

/* ═══════════════════════════════════════════════════════════════
   BACKGROUND STICKERS — floating emoji, GPU-composited via rAF
   JS creates these; CSS just positions them correctly.
═══════════════════════════════════════════════════════════════ */
.bg-sticker {
  position: fixed;
  pointer-events: none;
  z-index: 0;
  will-change: transform, opacity;
  user-select: none;
  animation: none; /* animation driven entirely by JS rAF, not CSS */
  line-height: 1;
}

/* ═══════════════════════════════════════════════════════════════
   PRINT STYLES — "Download as PDF" / window.print()
═══════════════════════════════════════════════════════════════ */
@media print{
  .gift-loading,.lock-screen,.envelope-screen,
  .confetti-canvas,.petal-overlay,
  .demo-banner,.reaction-section,.share-bar,
  footer,.pdf-btn,.preview-lock{display:none!important}

  body,html{background:#fff!important}
  .gift-page{background:#fff!important}
  .gift-content{max-width:100%!important;padding:0 44px!important;display:block!important;margin-top:0!important}
  .gift-hero{padding:32px 0 24px}
  .gift-title{font-size:3rem!important}
  .gift-section{page-break-inside:avoid;margin:32px 0}
  .gift-letter{box-shadow:none!important;border:1px solid #ddd!important;font-size:.97rem!important;line-height:1.8!important}
  .gift-poem{box-shadow:none!important;border:1px solid #ddd!important}
  .gift-final{background:#fff!important;border:1px solid #ddd!important;padding:30px!important}
  .fade-scroll{opacity:1!important;transform:none!important}
  .song-vinyl{display:none!important}
  .magazine-collage{grid-template-columns:repeat(3,1fr)!important}
  .magazine-collage .col-item{height:160px!important;grid-column:auto!important;grid-row:auto!important}
  .days-counter{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  @page{margin:18mm 14mm}
}
