:root {
  --g: #74b72e;
  --gd: #5a9022;
  --gl: #e8f5d0;
  --gp: #f4faea;
  --r: #900d09;
  --rl: #fde8e8;
  --pk: #ffb7c5;
  --pkl: #ffe8ee;
  --cr: #faf8f5;
  --wh: #ffffff;
  --tx: #2d1f1f;
  --txl: #7a6060;
  --bd: #e0d5c5;
  --sh: rgba(45,31,31,0.1);
  --booth-bg: #1a1410;
  --booth-frame: #f0ebe0;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Cormorant Garamond',serif;background:var(--cr);color:var(--tx);overflow-x:hidden;font-size:16px;}
h1,h2,h3,h4{font-family:'Playfair Display',serif;}
a{text-decoration:none;}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:900;background:rgba(250,248,245,0.96);backdrop-filter:blur(10px);border-bottom:1px solid var(--bd);height:62px;display:flex;align-items:center;justify-content:space-between;padding:0 2rem;}
.nav-logo{display:flex;align-items:center;gap:8px;font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--gd);font-style:italic;cursor:pointer;}
.nav-links{display:flex;gap:2px;list-style:none;flex-wrap:wrap;}
.nav-links a{color:var(--txl);font-size:.83rem;letter-spacing:.03em;padding:5px 11px;border-radius:20px;transition:all .2s;font-family:'Cormorant Garamond',serif;font-weight:500;}
.nav-links a:hover,.nav-links a.active{background:var(--gl);color:var(--gd);}

/* SECTIONS */
section{min-height:100vh;padding:90px 2rem 60px;position:relative;}
.sec-inner{max-width:1100px;margin:0 auto;}
.sec-title{font-size:2.6rem;color:var(--gd);font-style:italic;margin-bottom:.3rem;}
.sec-sub{font-size:1.1rem;color:var(--txl);font-style:italic;margin-bottom:2.2rem;}
.divider{display:flex;align-items:center;gap:12px;margin:1rem 0 2.2rem;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--bd);}
.divider span{font-size:1.2rem;}

/* BUTTONS */
.btn{padding:10px 22px;border-radius:30px;border:none;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:1rem;font-style:italic;transition:all .2s;display:inline-flex;align-items:center;gap:7px;}
.btn-green{background:var(--g);color:#fff;}
.btn-green:hover{background:var(--gd);transform:translateY(-1px);}
.btn-outline{background:transparent;border:1.5px solid var(--g);color:var(--gd);}
.btn-outline:hover{background:var(--gl);}
.btn-soft{background:var(--gl);color:var(--gd);}
.btn-soft:hover{background:#d4edaa;}
.btn-red{background:var(--rl);color:var(--r);}
.btn-red:hover{background:#fbd4d4;}
.btn-dark{background:#2d2218;color:#f0ebe0;}
.btn-dark:hover{background:#1a1410;}
.btn-sm{padding:7px 15px;font-size:.88rem;}

/* FORMS */
.form-group{margin-bottom:14px;}
.form-label{display:block;font-size:.8rem;color:var(--txl);margin-bottom:5px;letter-spacing:.05em;text-transform:uppercase;}
.form-input,.form-select,.form-textarea{width:100%;padding:9px 13px;border:1.5px solid var(--bd);border-radius:10px;font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--tx);background:var(--cr);outline:none;transition:border-color .2s;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--g);background:#fff;}
.form-textarea{resize:vertical;min-height:80px;}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(45,31,31,.5);z-index:2000;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal{background:#fff;border-radius:22px;padding:2.2rem;max-width:460px;width:100%;transform:scale(.92);transition:transform .3s;position:relative;max-height:92vh;overflow-y:auto;}
.modal-box{background:#fffdf7;border-radius:22px;padding:2.2rem;max-width:460px;width:100%;position:relative;max-height:92vh;overflow-y:auto;box-shadow:0 24px 64px rgba(45,31,31,.35);border:1.5px solid #e8d8b0;}
.modal-overlay.open .modal{transform:scale(1);}
.modal-close{position:absolute;top:14px;right:14px;background:var(--gl);border:none;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:.95rem;color:var(--gd);display:flex;align-items:center;justify-content:center;}
.modal-title{font-size:1.55rem;color:var(--gd);font-style:italic;margin-bottom:.3rem;}
.modal-sub{font-size:.9rem;color:var(--txl);font-style:italic;margin-bottom:1.4rem;}

/* ======================== HERO ======================== */
#home{background:linear-gradient(150deg,var(--gp) 0%,var(--cr) 55%,var(--pkl) 100%);display:flex;align-items:center;padding-top:62px;overflow:hidden;}
.hero-wrap{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;width:100%;padding:40px 0;}
.hero-text h1{font-size:4rem;line-height:1.08;color:var(--gd);margin-bottom:1rem;}
.hero-text h1 em{color:var(--r);font-style:italic;}
.hero-lead{font-size:1.2rem;color:var(--txl);font-style:italic;line-height:1.65;margin-bottom:2rem;}
.counter-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:1.5rem;}
.cnt-box{background:#fff;border-radius:14px;padding:14px 6px;text-align:center;box-shadow:0 4px 18px var(--sh);border:1px solid var(--bd);}
.cnt-n{font-family:'Playfair Display',serif;font-size:2rem;color:var(--gd);display:block;line-height:1;}
.cnt-l{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--txl);margin-top:3px;display:block;}
.badge{display:inline-flex;align-items:center;gap:8px;background:var(--gl);border:1px solid var(--g);border-radius:30px;padding:7px 16px;font-size:.9rem;color:var(--gd);font-style:italic;}
.hero-visual{position:relative;height:480px;display:flex;justify-content:center;align-items:flex-end;}
.tulip-stage{position:relative;width:320px;height:420px;}
.tulip{position:absolute;bottom:0;transform-origin:bottom center;animation:sway 5s ease-in-out infinite;}
.tulip:nth-child(1){left:10px;animation-duration:4.8s;animation-delay:0s;}
.tulip:nth-child(2){left:80px;animation-duration:5.2s;animation-delay:.6s;}
.tulip:nth-child(3){left:155px;animation-duration:4.6s;animation-delay:1.2s;}
.tulip:nth-child(4){left:230px;animation-duration:5s;animation-delay:.3s;}
@keyframes sway{0%,100%{transform:rotate(-3deg);}50%{transform:rotate(3deg);}}
.petal{position:fixed;pointer-events:none;z-index:1;border-radius:50% 50% 50% 0;opacity:0;animation:pfloat linear forwards;}
@keyframes pfloat{0%{opacity:.7;transform:translateY(-10px) rotate(0deg);}100%{opacity:0;transform:translateY(110vh) rotate(480deg) translateX(80px);}}

/* ======================== CALENDAR ======================== */
#calendar{background:var(--cr);}
.cal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:14px;margin-top:1.5rem;}
.door{aspect-ratio:3/4;border-radius:16px;cursor:pointer;position:relative;transition:transform .2s,box-shadow .2s;overflow:hidden;border:2px solid transparent;}
.door:hover{transform:translateY(-5px);box-shadow:0 14px 40px var(--sh);}
.door.locked{background:linear-gradient(145deg,#ede5d8,#ddd0be);border-color:var(--bd);}
.door.unlocked{background:linear-gradient(145deg,var(--gl),#cbeba0);border-color:var(--g);animation:glowPulse 2.5s ease-in-out infinite;}
.door.opened{background:linear-gradient(145deg,#fffaf5,#fff4ed);border-color:var(--pk);}
.door.custom-door{background:linear-gradient(145deg,#fff0f3,#ffe8f0);border-color:var(--pk);}
.door.custom-door.unlocked{background:linear-gradient(145deg,#ffe8f0,#ffd5e5);border-color:var(--r);}
@keyframes glowPulse{0%,100%{box-shadow:0 0 0 0 rgba(116,183,46,0);}50%{box-shadow:0 0 12px 3px rgba(116,183,46,.3);}}
.door-inner{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px;text-align:center;gap:5px;}
.door-num{font-family:'Playfair Display',serif;font-size:2rem;color:var(--gd);opacity:.25;line-height:1;}
.door.unlocked .door-num,.door.opened .door-num{opacity:.5;}
.door-ico{font-size:2rem;line-height:1;}
.door-lbl{font-size:.72rem;color:var(--txl);font-style:italic;line-height:1.3;}
.door.unlocked .door-lbl{color:var(--gd);}
.door-cd{font-size:.65rem;color:var(--txl);font-style:italic;}
.lock-ico{font-size:1.3rem;opacity:.25;margin-bottom:4px;}
.door-note-preview{font-size:.65rem;color:var(--txl);font-style:italic;border-top:1px solid rgba(0,0,0,.08);padding-top:5px;margin-top:3px;max-width:100%;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;}
.add-door-btn{aspect-ratio:3/4;border-radius:16px;border:2px dashed var(--g);background:transparent;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--gd);font-family:'Cormorant Garamond',serif;font-size:.88rem;font-style:italic;transition:background .2s;}
.add-door-btn:hover{background:var(--gp);}
.add-door-btn .big{font-size:1.8rem;}

/* ======================== DATES ======================== */
#dates{background:var(--gp);}
.dates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:14px;}
.date-card{background:#fff;border-radius:15px;padding:18px;border:1px solid var(--bd);display:flex;gap:14px;align-items:flex-start;transition:transform .2s,box-shadow .2s;position:relative;}
.date-card:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--sh);}
.date-icon-b{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;}
.date-card.anni .date-icon-b{background:var(--rl);}
.date-card.monthly .date-icon-b{background:var(--gl);}
.date-card.custom .date-icon-b{background:var(--pkl);}
.date-info h4{font-size:.97rem;margin-bottom:2px;}
.date-str{font-size:.82rem;color:var(--txl);font-style:italic;}
.date-cd{font-size:.78rem;color:var(--gd);font-weight:600;margin-top:4px;}
.date-del{position:absolute;top:10px;right:10px;background:none;border:none;color:var(--txl);cursor:pointer;font-size:.8rem;opacity:0;padding:3px 6px;border-radius:6px;transition:all .2s;}
.date-card:hover .date-del{opacity:1;}
.date-del:hover{background:var(--rl);color:var(--r);}
.add-date-wrap{background:#fff;border:2px dashed var(--g);border-radius:15px;padding:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--gd);font-family:'Cormorant Garamond',serif;font-size:.97rem;font-style:italic;transition:background .2s;height:86px;}
.add-date-wrap:hover{background:var(--gp);}

/* ======================== MEMORIES ======================== */
#memories{background:var(--cr);}
.mem-controls{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px;}
.photo-grid{columns:3 190px;gap:12px;column-gap:12px;}
.photo-card{break-inside:avoid;border-radius:12px;overflow:hidden;position:relative;background:var(--gp);cursor:pointer;box-shadow:0 4px 18px var(--sh);transition:transform .2s;margin-bottom:12px;display:inline-block;width:100%;}
.photo-card:hover{transform:scale(1.025);}
.photo-card:hover .photo-ov{opacity:1;}
.photo-card img{width:100%;height:auto;display:block;object-fit:contain;}
.photo-ov{position:absolute;inset:0;background:rgba(45,31,31,.45);display:flex;flex-direction:column;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;gap:8px;}
.photo-cap{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(0deg,rgba(45,31,31,.75),transparent);color:#fff;padding:20px 10px 8px;font-size:.78rem;font-style:italic;}
.photo-del{background:rgba(144,13,9,.8);color:#fff;border:none;border-radius:8px;padding:5px 10px;cursor:pointer;font-size:.8rem;font-family:'Cormorant Garamond',serif;}
.empty-state{text-align:center;padding:60px 20px;color:var(--txl);font-style:italic;font-size:1.05rem;grid-column:1/-1;}
.empty-state .e-ico{font-size:3rem;display:block;margin-bottom:1rem;}

/* ======================== PHOTO BOOTH ======================== */
#photobooth{background:var(--booth-bg);position:relative;overflow:hidden;}
#photobooth::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.015) 2px,rgba(255,255,255,.015) 4px);pointer-events:none;z-index:0;}
#photobooth .sec-inner{position:relative;z-index:1;}
#photobooth .sec-title{color:#e8dfc8;}
#photobooth .sec-sub{color:#8a7a60;}
#photobooth .divider::before,#photobooth .divider::after{background:#3a2e20;}

/* Booth tabs */
.booth-tabs{display:flex;gap:4px;background:#2d2218;border-radius:14px;padding:4px;margin-bottom:2rem;width:fit-content;}
.booth-tab{padding:9px 20px;border-radius:10px;border:none;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:.95rem;font-style:italic;color:#8a7a60;background:transparent;transition:all .2s;}
.booth-tab.active{background:#3d3025;color:#e8dfc8;}

/* Booth layout */
.booth-layout{display:grid;grid-template-columns:1fr auto;gap:3rem;align-items:start;}
.booth-controls-col{flex:1;}

/* Camera preview — portrait */
.cam-preview-wrap{background:#0d0b08;border-radius:16px;overflow:hidden;aspect-ratio:3/4;position:relative;max-width:340px;border:3px solid #3a2e20;}
.cam-preview-wrap video{width:100%;height:100%;object-fit:cover;display:block;transform:scaleX(-1);}
.cam-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.75);flex-direction:column;gap:12px;color:#e8dfc8;font-style:italic;z-index:5;}
.cam-overlay .cam-ico{font-size:3rem;}
.countdown-num{display:none;}

/* In-camera countdown overlay — sits over the live feed so you can see yourself */
.cam-cd-overlay{position:absolute;inset:0;z-index:20;display:flex;flex-direction:column;align-items:center;justify-content:center;background:rgba(0,0,0,.38);opacity:0;pointer-events:none;transition:opacity .2s;gap:0;padding-bottom:60px;}
.cam-cd-overlay.show{opacity:1;}

/* Big number — centred directly in overlay, no ring */
.cam-cd-num{display:flex;align-items:center;justify-content:center;width:140px;height:140px;font-family:'Playfair Display',serif;font-size:9rem;color:#fff;line-height:1;text-shadow:0 0 60px rgba(255,255,255,.9),0 0 20px rgba(116,183,46,.8);transform-origin:center center;animation:cdBounce .9s cubic-bezier(.36,.07,.19,.97);}
@keyframes cdBounce{0%{transform:scale(1.4);opacity:0;}40%{opacity:1;transform:scale(0.9);}60%{transform:scale(1.06);}100%{transform:scale(1);}}
.cam-cd-smile{display:flex;align-items:center;justify-content:center;width:140px;height:140px;font-size:5.5rem;transform-origin:center center;animation:cdBounce .5s ease;}

/* Label + dots directly below number */
.cam-cd-bottom{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:18px;}
.cam-cd-label{font-family:'Cormorant Garamond',serif;font-size:1rem;color:rgba(255,255,255,.92);font-style:italic;letter-spacing:.08em;text-align:center;}
.cam-cd-dots{display:flex;gap:10px;}
.cam-cd-dot{width:11px;height:11px;border-radius:50%;background:rgba(255,255,255,.25);transition:all .3s;border:1.5px solid rgba(255,255,255,.3);}
.cam-cd-dot.done{background:#74b72e;border-color:#74b72e;}
.cam-cd-dot.active{background:#fff;border-color:#fff;transform:scale(1.35);}

/* Flash effect on capture */
.cam-flash{position:absolute;inset:0;background:#fff;z-index:30;opacity:0;pointer-events:none;border-radius:13px;}
.cam-flash.flash{animation:camFlash .35s ease-out forwards;}
@keyframes camFlash{0%{opacity:.95;}100%{opacity:0;}}
.frame-strip-preview{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap;}
.frame-prev-thumb{width:52px;height:70px;border-radius:6px;overflow:hidden;border:2px solid #3a2e20;background:#1a1410;position:relative;}
.frame-prev-thumb img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.15);}
.frame-prev-thumb.empty::after{content:attr(data-n);position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#5a4a35;font-family:'Playfair Display',serif;font-size:1.3rem;}
.booth-status{font-size:.9rem;color:#8a7a60;font-style:italic;margin-top:12px;min-height:22px;}

/* Upload grid */
.upload-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;max-width:400px;}
.upload-slot.drag-over{border-color:var(--g) !important;background:var(--gl) !important;transform:scale(1.03);}
.upload-slot{aspect-ratio:1;border:2px dashed #3a2e20;border-radius:12px;background:#1a1410;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#5a4a35;font-size:.8rem;font-style:italic;overflow:hidden;position:relative;transition:border-color .2s;}
.upload-slot:hover{border-color:#7a6040;}
.upload-slot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.1);}
.upload-slot .slot-label{position:relative;z-index:1;background:rgba(0,0,0,.6);padding:3px 8px;border-radius:20px;font-size:.7rem;color:#c0a870;}
.upload-slot input{display:none;}

/* Strip display */
.strip-display-col{display:flex;flex-direction:column;align-items:center;gap:16px;}
.strip-wrap{background:#f5f0e8;padding:14px 14px 30px;border-radius:4px;box-shadow:0 20px 60px rgba(0,0,0,.7),0 0 0 1px rgba(0,0,0,.15);width:240px;}
.strip-frame{width:200px;height:267px;overflow:hidden;background:#d8cfc0;margin-bottom:16px;position:relative;}
.strip-frame:last-child{margin-bottom:0;}
.strip-frame canvas{width:100%;height:100%;display:block;}
.strip-frame.empty-frame{display:flex;align-items:center;justify-content:center;color:#b0a090;background:#ddd5c5;font-family:'Playfair Display',serif;font-size:1.4rem;}
.strip-date-label{text-align:center;color:#8a7060;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;margin-top:12px;font-family:'Cormorant Garamond',serif;}

/* Saved strips gallery */
.strips-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:20px;margin-top:1.5rem;}
.saved-strip{cursor:pointer;transition:transform .2s;position:relative;}
.saved-strip:hover{transform:scale(1.04);}
.saved-strip img{width:100%;border-radius:4px;box-shadow:0 8px 24px rgba(0,0,0,.5);}
.saved-strip-del{position:absolute;top:-6px;right:-6px;width:22px;height:22px;background:var(--r);border:none;border-radius:50%;color:#fff;font-size:.7rem;cursor:pointer;display:none;align-items:center;justify-content:center;}
.saved-strip-dl{position:absolute;top:-6px;left:-6px;width:22px;height:22px;background:#74b72e;border:none;border-radius:50%;color:#fff;font-size:.7rem;cursor:pointer;display:none;align-items:center;justify-content:center;}
.saved-strip:hover .saved-strip-del{display:flex;}
.saved-strip:hover .saved-strip-dl{display:flex;}

/* ======================== LIGHTBOX ======================== */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:3000;display:flex;align-items:center;justify-content:center;padding:1.5rem;opacity:0;pointer-events:none;transition:opacity .3s;}
.lightbox.open{opacity:1;pointer-events:all;}
.lightbox img{max-width:80vw;max-height:82vh;border-radius:10px;object-fit:contain;}
.lb-close{position:absolute;top:18px;right:18px;background:rgba(255,255,255,.15);border:none;color:#fff;width:42px;height:42px;border-radius:50%;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:#fff;width:50px;height:50px;border-radius:50%;font-size:2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;line-height:1;}
.lb-nav:hover{background:rgba(255,255,255,.3);}
.lb-prev{left:18px;}
.lb-next{right:18px;}
.lb-cap{position:absolute;bottom:38px;left:50%;transform:translateX(-50%);color:#fff;font-style:italic;font-size:1rem;text-align:center;max-width:500px;}
.lb-counter{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:.78rem;}
.lb-download{position:absolute;top:18px;left:18px;background:rgba(255,255,255,.15);border:none;color:#fff;width:42px;height:42px;border-radius:50%;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;}
.lb-download:hover{background:rgba(255,255,255,.3);}

/* ======================== GAMES ======================== */
#games{background:var(--gp);}
.games-hub{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:18px;margin-bottom:2.5rem;}
.game-card{background:#fff;border-radius:18px;padding:26px 18px;text-align:center;cursor:pointer;transition:transform .2s,box-shadow .2s,border-color .2s;border:2px solid var(--bd);position:relative;overflow:hidden;}
.game-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--g);transform:scaleX(0);transition:transform .25s;}
.game-card:hover{transform:translateY(-4px);box-shadow:0 12px 38px var(--sh);border-color:var(--g);}
.game-card:hover::after{transform:scaleX(1);}
.game-card .g-ico{font-size:2.4rem;display:block;margin-bottom:10px;}
.game-card h3{font-size:1.15rem;color:var(--tx);margin-bottom:5px;}
.game-card p{font-size:.86rem;color:var(--txl);font-style:italic;}
/* ======================== GAME MODAL ======================== */
.game-modal{position:fixed;inset:0;z-index:2000;display:flex;flex-direction:column;background:var(--cr);opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;transform:translateY(30px);}
.game-modal.open{opacity:1;pointer-events:all;transform:translateY(0);}
.gm-bar{display:flex;align-items:center;justify-content:space-between;padding:16px 28px;background:#fff;border-bottom:1px solid var(--bd);flex-shrink:0;}
.gm-bar-left{display:flex;align-items:center;gap:14px;}
.gm-bar h3{font-size:1.6rem;color:var(--gd);font-style:italic;}
.gm-close{width:40px;height:40px;border-radius:50%;background:var(--gl);border:none;cursor:pointer;font-size:1.1rem;display:flex;align-items:center;justify-content:center;color:var(--gd);transition:background .2s;}
.gm-close:hover{background:var(--bd);}
.gm-body{flex:1;overflow-y:auto;padding:2.5rem 3rem;display:flex;flex-direction:column;align-items:center;}
.gm-body > *{width:100%;max-width:860px;}
.game-area{display:none;}
.game-area.active{display:block;}

/* Memory Match */
.mem-game-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:440px;margin:0 auto 1.5rem;}
.mc{aspect-ratio:1;cursor:pointer;perspective:500px;}
.mc-in{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .45s;border-radius:12px;}
.mc.flip .mc-in{transform:rotateY(180deg);}
.mc-f,.mc-b{position:absolute;inset:0;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;backface-visibility:hidden;}
.mc-f{background:linear-gradient(135deg,var(--gl),#c6e88a);border:2px solid var(--g);}
.mc-f::after{content:'🌷';font-size:1.2rem;}
.mc-b{background:#fff;border:2px solid var(--pk);transform:rotateY(180deg);}
.mc.matched .mc-b{background:var(--gl);border-color:var(--g);}
.mc.no-click{pointer-events:none;}
.mem-stats{display:flex;justify-content:center;gap:2rem;margin-bottom:1.2rem;font-size:.95rem;color:var(--txl);}
.mem-stats strong{color:var(--gd);font-family:'Playfair Display',serif;font-size:1.3rem;}
.win-msg{text-align:center;padding:1.5rem;animation:fadeUp .4s ease;}
.win-msg .win-num{font-family:'Playfair Display',serif;font-size:3.5rem;color:var(--gd);}

/* Quiz */
.quiz-gender-toggle{display:flex;gap:6px;background:var(--gl);border-radius:30px;padding:4px;width:fit-content;margin-bottom:1.4rem;}
.qgt-btn{padding:7px 18px;border-radius:26px;border:none;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:.9rem;font-style:italic;background:transparent;color:var(--gd);transition:all .2s;}
.qgt-btn.active{background:#fff;box-shadow:0 2px 8px var(--sh);}
.quiz-prog{display:flex;gap:6px;margin-bottom:1.4rem;}
.q-dot{width:10px;height:10px;border-radius:50%;background:var(--bd);}
.q-dot.done{background:var(--g);}
.q-dot.cur{background:var(--g);opacity:.5;}
.quiz-q{font-size:1.3rem;color:var(--tx);margin-bottom:1.4rem;line-height:1.5;font-style:italic;}
.quiz-opts{display:grid;gap:9px;}
.quiz-opt{padding:13px 18px;border-radius:12px;border:2px solid var(--bd);background:#fff;text-align:left;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:1rem;color:var(--tx);transition:all .2s;}
.quiz-opt:hover:not(:disabled){border-color:var(--g);background:var(--gp);}
.quiz-opt.correct{border-color:var(--g);background:var(--gl);color:var(--gd);}
.quiz-opt.wrong{border-color:var(--r);background:var(--rl);color:var(--r);}
.quiz-opt:disabled{cursor:default;}
.quiz-fb{margin-top:1rem;font-style:italic;font-size:.95rem;}
.quiz-fb.good{color:var(--gd);}
.quiz-fb.bad{color:var(--r);}

/* Would You Rather */
.wyr-wrap{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;margin-bottom:1.5rem;}
.wyr-opt{background:var(--cr);border:2px solid var(--bd);border-radius:18px;padding:22px;text-align:center;cursor:pointer;font-size:1.05rem;font-style:italic;color:var(--tx);transition:all .2s;line-height:1.5;font-family:'Cormorant Garamond',serif;width:100%;}
.wyr-opt:hover{border-color:var(--g);background:var(--gp);transform:scale(1.02);}
.wyr-opt.chosen{border-color:var(--g);background:var(--gl);color:var(--gd);}
.wyr-opt.unchosen{opacity:.45;}
.wyr-or{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--txl);font-style:italic;text-align:center;}
.wyr-results-wrap{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:.5rem;}
.wyr-result-item{display:flex;gap:12px;align-items:flex-start;background:var(--gl);border-radius:12px;padding:12px 14px;}
.wyr-ri-num{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--gd);font-weight:700;min-width:30px;}
.wyr-ri-body{flex:1;}
.wyr-ri-chosen{color:var(--gd);font-weight:600;margin-bottom:4px;font-size:.92rem;}
.wyr-ri-other{color:#aaa;font-style:italic;font-size:.85rem;text-decoration:line-through;}
.wyr-result{text-align:center;font-style:italic;font-size:1rem;color:var(--txl);margin-top:.5rem;min-height:30px;}

/* ======================== UTILS ======================== */
.hidden{display:none!important;}
.flex-c{display:flex;align-items:center;justify-content:center;}
.t-center{text-align:center;}
.mt-1{margin-top:10px;}
.mt-2{margin-top:18px;}
.gap-row{display:flex;gap:10px;flex-wrap:wrap;}
.tag{display:inline-block;background:var(--gl);color:var(--gd);border-radius:20px;padding:3px 10px;font-size:.75rem;font-style:italic;}

/* ======================== ABOUT HER ======================== */
#abouther{background:linear-gradient(160deg,#12100e 0%,#1e1810 40%,#0f1408 100%);position:relative;overflow:hidden;}
#abouther::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(196,160,40,.07),transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(116,183,46,.06),transparent 50%);pointer-events:none;}
#abouther .sec-inner{position:relative;z-index:1;}
#abouther .sec-title{color:#e8d48a;font-size:3rem;}
#abouther .sec-sub{color:#8a7a50;}
#abouther .divider::before,#abouther .divider::after{background:#3a3020;}
#abouther .divider span{filter:brightness(1.2);}

.ah-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;}
.ah-card{background:rgba(255,255,255,.04);border:1px solid rgba(196,160,40,.2);border-radius:18px;padding:22px;backdrop-filter:blur(4px);transition:border-color .3s,transform .2s;}
.ah-card:hover{border-color:rgba(196,160,40,.45);transform:translateY(-3px);}
.ah-card-head{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.ah-card-ico{width:42px;height:42px;border-radius:12px;background:rgba(196,160,40,.12);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0;}
.ah-card-head h3{font-family:'Playfair Display',serif;font-size:1.1rem;color:#e8d48a;font-style:italic;}
.ah-pills{display:flex;flex-wrap:wrap;gap:7px;}
.ah-pill{background:rgba(255,255,255,.06);border:1px solid rgba(196,160,40,.18);border-radius:20px;padding:5px 13px;font-size:.82rem;color:#c8b878;font-style:italic;transition:all .2s;}
.ah-pill:hover{background:rgba(196,160,40,.12);border-color:rgba(196,160,40,.4);}
.ah-pill.green{border-color:rgba(116,183,46,.3);color:#a8d870;}
.ah-pill.green:hover{background:rgba(116,183,46,.1);}
.ah-dream-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:1.5rem;}
.ah-place{background:rgba(255,255,255,.04);border:1px solid rgba(196,160,40,.15);border-radius:14px;padding:16px;text-align:center;}
.ah-place .pi{font-size:2rem;margin-bottom:6px;}
.ah-place h4{font-size:.95rem;color:#e8d48a;font-family:'Playfair Display',serif;font-style:italic;margin-bottom:4px;}
.ah-place p{font-size:.78rem;color:#7a6a45;font-style:italic;}
.ah-date-row{display:flex;flex-wrap:wrap;gap:8px;}
.ah-date-chip{background:rgba(116,183,46,.1);border:1px solid rgba(116,183,46,.25);border-radius:20px;padding:6px 14px;font-size:.82rem;color:#a8d870;font-style:italic;}

/* ======================== NEW GAMES CSS ======================== */
/* Trivia */
.trivia-q{font-size:1.25rem;color:var(--tx);margin-bottom:1.2rem;line-height:1.55;font-style:italic;}
.trivia-opts{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:1rem;}
.trivia-opt{padding:13px;border-radius:12px;border:2px solid var(--bd);background:#fff;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:.97rem;color:var(--tx);transition:all .2s;text-align:center;}
.trivia-opt:hover:not(:disabled){border-color:var(--g);background:var(--gp);}
.trivia-opt.t-correct{border-color:var(--g);background:var(--gl);color:var(--gd);}
.trivia-opt.t-wrong{border-color:var(--r);background:var(--rl);color:var(--r);}
.trivia-score-bar{display:flex;justify-content:center;gap:2rem;margin-bottom:1.4rem;font-size:.95rem;color:var(--txl);}
.trivia-score-bar strong{color:var(--gd);font-family:'Playfair Display',serif;font-size:1.3rem;}

/* Wordle */
.wordle-board{display:grid;grid-template-rows:repeat(6,1fr);gap:6px;width:fit-content;margin:0 auto 1.5rem;}
.wordle-row{display:grid;grid-template-columns:repeat(5,52px);gap:6px;}
.wordle-cell{
  width:52px;height:52px;
  border:2px solid #d0c8b8;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;
  color:#333;background:#fff;
  transition:background .15s, border-color .15s, color .15s;
}
.wordle-cell.filled{border-color:#888;}
@keyframes wPop{0%{transform:scale(1.13);}100%{transform:scale(1);}}
.wordle-cell.filled{animation:wPop .12s ease;}
.wordle-cell.correct{background:#74b72e !important;border-color:#74b72e !important;color:#fff !important;}
.wordle-cell.present{background:#d4a017 !important;border-color:#d4a017 !important;color:#fff !important;}
.wordle-cell.absent {background:#c0392b !important;border-color:#c0392b !important;color:#fff !important;}
.wordle-cell.shake{animation:wShake .4s ease;}
@keyframes wShake{0%,100%{transform:translateX(0);}25%{transform:translateX(-6px);}75%{transform:translateX(6px);}}
.wordle-keyboard{display:flex;flex-direction:column;gap:6px;align-items:center;margin:0 auto;}
.wordle-kb-row{display:flex;gap:5px;}
.wk{min-width:34px;height:40px;border-radius:6px;border:none;background:#e0d5c5;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:.9rem;font-weight:600;color:var(--tx);transition:background .2s;padding:0 6px;}
.wk:hover{background:#c8bca8;}
.wk.wk-correct{background:#74b72e;color:#fff;}
.wk.wk-present{background:#d4a017;color:#fff;}
.wk.wk-absent {background:#c0392b;color:#fff;}
.wk.wk-wide{min-width:54px;font-size:.78rem;}
.wordle-msg{text-align:center;min-height:28px;font-style:italic;font-size:1rem;color:var(--gd);margin-bottom:.5rem;}

/* Hint system */
.wordle-hint-row{display:flex;align-items:center;gap:12px;margin-bottom:1rem;flex-wrap:wrap;}
.wordle-hint-btn{display:flex;align-items:center;gap:7px;padding:8px 16px;border-radius:20px;border:2px solid var(--g);background:var(--gp);color:var(--gd);cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:.95rem;font-style:italic;transition:all .2s;}
.wordle-hint-btn:hover:not(:disabled){background:var(--gl);}
.wordle-hint-btn:disabled{opacity:.45;cursor:default;}
.wordle-hint-count{font-size:.82rem;color:var(--txl);font-style:italic;}
.wordle-hint-reveal{background:var(--gl);border-radius:10px;padding:10px 16px;font-style:italic;font-size:.95rem;color:var(--gd);margin-bottom:.8rem;min-height:36px;border-left:3px solid var(--g);}

/* Colour legend */
.wordle-legend{display:flex;gap:14px;margin-bottom:1rem;flex-wrap:wrap;}
.wl-item{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--txl);font-style:italic;}
.wl-swatch{width:20px;height:20px;border-radius:4px;flex-shrink:0;}
.wl-green{background:#74b72e;}
.wl-yellow{background:#d4a017;}
.wl-red{background:#c0392b;}

/* Block Blast */
.bb-wrap{display:flex;gap:28px;align-items:flex-start;flex-wrap:wrap;}
.bb-board-wrap{position:relative;}
.bb-board{display:grid;grid-template-columns:repeat(8,44px);grid-template-rows:repeat(8,44px);gap:3px;}
.bb-cell{width:44px;height:44px;border-radius:6px;background:#f0ebe0;border:1px solid #e0d5c5;transition:background .15s;}
.bb-cell.filled{background:var(--g);border-color:var(--gd);}
.bb-cell.preview{background:#c8e899;border-color:#a0c870;}
.bb-cell.highlight-clear{background:#ffb7c5;border-color:#f090a0;animation:bbPop .3s ease;}
/* ── Block Blast touch ghost ── */
.bb-touch-ghost{
  position:fixed;pointer-events:none;z-index:9999;
  display:grid;gap:3px;opacity:.75;
  transform:translate(-50%,-50%);
  transition:none;
}
.bb-touch-ghost .bb-piece-cell.on{
  width:38px;height:38px;border-radius:4px;background:var(--g);
}
.bb-touch-ghost .bb-piece-cell.off{
  width:38px;height:38px;border-radius:4px;background:transparent;
}

@keyframes bbPop{0%{transform:scale(1.2);}100%{transform:scale(1);}}
.bb-pieces{display:flex;flex-direction:column;gap:14px;}
.bb-piece{cursor:pointer;padding:8px;border-radius:10px;border:2px solid transparent;transition:border-color .2s;}
.bb-piece.selected{border-color:var(--g);background:var(--gp);}
.bb-piece-grid{display:grid;gap:3px;}
.bb-piece-cell{width:24px;height:24px;border-radius:4px;}
.bb-piece-cell.on{background:var(--g);}
.bb-piece-cell.off{background:transparent;}
.bb-score-row{display:flex;gap:1.5rem;margin-bottom:1rem;font-size:.95rem;color:var(--txl);}
.bb-score-row strong{color:var(--gd);font-family:'Playfair Display',serif;font-size:1.3rem;}

/* Flappy Trivia */
.ft-wrap{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap;}
.ft-q-panel{flex:1;min-width:220px;}
.ft-q{font-size:1.1rem;color:var(--tx);font-style:italic;line-height:1.5;margin-bottom:1rem;min-height:60px;}
.ft-hint{font-size:.82rem;color:var(--txl);font-style:italic;margin-bottom:1rem;}
.ft-ans-labels{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:.5rem;}
.ft-ans-pill{padding:10px 14px;border-radius:12px;font-size:.9rem;font-style:italic;text-align:center;border:2px solid var(--bd);color:var(--tx);}
.ft-ans-pill.top-ans{border-color:#74b72e;background:var(--gp);color:var(--gd);}
.ft-ans-pill.bot-ans{border-color:#d4a017;background:#fdf6e0;color:#a07800;}
.ft-canvas-wrap{position:relative;}
#ftCanvas{border-radius:12px;border:2px solid var(--bd);display:block;background:#e8f5d0;}
.ft-score-wrap{display:flex;gap:1.5rem;margin-bottom:1rem;font-size:.95rem;color:var(--txl);}
.ft-score-wrap strong{color:var(--gd);font-family:'Playfair Display',serif;font-size:1.3rem;}

@media(max-width:768px){
  .hero-wrap{grid-template-columns:1fr;text-align:center;}
  .hero-visual{display:none;}
  .hero-text h1{font-size:2.8rem;}
  .counter-row{grid-template-columns:repeat(2,1fr);}
  .sec-title{font-size:2rem;}
  nav{padding:0 1rem;}
  .nav-links a{padding:4px 8px;font-size:.78rem;}
  section{padding:80px 1rem 50px;}
  /* Photobooth — stack camera above strip preview */
  .booth-layout{grid-template-columns:1fr;}
  .strip-display-col{flex-direction:row;justify-content:center;flex-wrap:wrap;}
  .cam-preview-wrap{max-width:100%;}
  /* Games */
  .trivia-opts{grid-template-columns:1fr;}
  .wordle-row{grid-template-columns:repeat(5,44px);}
  .wordle-cell{width:44px;height:44px;font-size:1.3rem;}
  .bb-wrap{flex-direction:column;}
  .bb-board{grid-template-columns:repeat(8,38px);grid-template-rows:repeat(8,38px);}
  .bb-cell{width:38px;height:38px;}
  .ft-wrap{flex-direction:column;}
  .wyr-wrap{grid-template-columns:1fr;gap:10px;}
  .wyr-or{transform:none;}
  /* About Her */
  .ah-grid{grid-template-columns:1fr;}
  /* Game modal */
  .gm-body{padding:1.5rem 1rem;}
  .gm-bar{padding:12px 16px;}
}

/* ─── Calendar Fullscreen Overlay ─── */
.cal-fs-overlay{position:fixed;inset:0;z-index:1800;background:#fffdf8;overflow-y:auto;
  opacity:0;pointer-events:none;transform:scale(.96);
  transition:opacity .35s cubic-bezier(.4,0,.2,1),transform .35s cubic-bezier(.4,0,.2,1);}
.cal-fs-overlay.open{opacity:1;pointer-events:all;transform:scale(1);}
.cal-fs-inner{max-width:780px;margin:0 auto;padding:40px 24px 80px;}
.cal-fs-close{background:var(--gl);border:none;color:var(--gd);cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:1rem;padding:8px 18px;border-radius:20px;margin-bottom:2rem;transition:background .2s;}
.cal-fs-close:hover{background:var(--bd);}
.cal-fs-hero{text-align:center;padding:2rem 0 2.5rem;}
.cal-fs-hero.locked{opacity:.8;}
.cal-fs-icon{font-size:4rem;margin-bottom:.8rem;}
.cal-fs-title{font-family:'Playfair Display',serif;font-size:2.4rem;color:var(--gd);margin-bottom:.4rem;}
.cal-fs-date{font-style:italic;color:var(--txl);margin-bottom:1rem;font-size:1rem;}
.cal-fs-msg{color:var(--tx);font-size:1.05rem;line-height:1.65;max-width:520px;margin:0 auto;}
.cal-fs-section{background:#fff;border:1px solid var(--bd);border-radius:16px;padding:22px 24px;margin-bottom:1.4rem;}
.cal-fs-sh{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--gd);margin-bottom:1rem;}
.cal-fs-photos{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px;}
.cal-fs-photo-wrap{position:relative;width:110px;height:110px;}
.cal-fs-photo-wrap img{width:100%;height:100%;object-fit:cover;border-radius:10px;cursor:pointer;transition:transform .2s;}
.cal-fs-photo-wrap img:hover{transform:scale(1.05);}
.cal-fs-photo-del{position:absolute;top:-6px;right:-6px;width:20px;height:20px;background:var(--r);border:none;color:#fff;border-radius:50%;font-size:.65rem;cursor:pointer;display:none;align-items:center;justify-content:center;}
.cal-fs-photo-wrap:hover .cal-fs-photo-del{display:flex;}
.cal-fs-add-photo{width:110px;height:110px;border:2px dashed var(--bd);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;color:var(--txl);font-size:1.6rem;transition:border-color .2s,background .2s;}
.cal-fs-add-photo:hover{border-color:var(--g);background:var(--gl);}
.cal-fs-poems{display:flex;flex-direction:column;gap:10px;margin-bottom:10px;}
.cal-fs-poem{position:relative;background:var(--gp);border-radius:10px;padding:14px 16px;}
.cal-fs-poem-text{font-family:'Cormorant Garamond',serif;font-size:.95rem;white-space:pre-wrap;color:var(--tx);margin:0;}
.cal-fs-poem-del{position:absolute;top:8px;right:8px;background:var(--r);border:none;color:#fff;width:24px;height:24px;border-radius:50%;font-size:.65rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .15s;}
.cal-fs-poem-del:hover{opacity:1;}

/* ─── Envelope Card — Full Screen ─── */
.env-overlay{
  position:fixed;inset:0;z-index:2100;
  background:linear-gradient(135deg,#1a0a0a 0%,#0d0505 60%,#1a0808 100%);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .5s ease;overflow:hidden;
}
.env-overlay.open{opacity:1;pointer-events:all;}

/* ── Stage 1: Envelope ── */
.env-stage-envelope{
  display:flex;flex-direction:column;align-items:center;
  transition:opacity .5s ease, transform .5s ease;
}
.env-stage-envelope.hide{opacity:0;transform:scale(.94);pointer-events:none;}

/* The envelope itself */
.envelope{
  position:relative;
  width:420px;
  cursor:pointer;
  perspective:1200px;
  transform-style:preserve-3d;
  /* Height = V-sides height (130px) + bottom bar (80px) = 210px */
  height:210px;
}
/* Clip mask so letter paper cannot be seen above the envelope body before opening */
.env-letter-paper-clip{
  position:absolute;
  bottom:0;left:0;right:0;
  height:210px;
  overflow:hidden;
  pointer-events:none;
  z-index:0;
}
/* Bottom bar */
.icon-envelope{
  position:absolute;
  bottom:0;left:0;
  z-index:1;
  width:420px;
  height:80px;
  background:#c8b09a;
  box-shadow:0 8px 0 #a08060;
}
/* Left V-side — triangle going bottom-left to centre-top */
.icon-envelope::before{
  z-index:1;position:absolute;display:block;content:'';
  top:-130px;left:0;width:0;height:0;
  border-style:solid;border-width:130px 0 0 210px;
  border-color:transparent transparent transparent #c8b09a;
}
/* Right V-side — triangle going bottom-right to centre-top */
.icon-envelope::after{
  z-index:1;display:block;content:'';position:absolute;
  top:-130px;right:0;width:0;height:0;
  border-style:solid;border-width:0 0 130px 210px;
  border-color:transparent transparent #c8b09a transparent;
}
/* Top flap — pointing DOWN (closed). Must exactly match V-side height (130px) */
.env-header{
  z-index:2;
  position:absolute;
  top:0;left:0;
  display:block;
  width:0;height:0;
  border-style:solid;
  /* pointing-down triangle: 130px tall, 420px wide */
  border-width:130px 210px 0 210px;
  border-color:#a08060 transparent transparent transparent;
  transform-origin:50% 0%;
  transition:transform 1s cubic-bezier(.4,0,.2,1), border-color .3s;
}
/* Inner face of flap — slightly lighter, offset to show depth */
.env-header::before{
  display:block;content:'';position:absolute;
  top:-130px;left:-207px;
  width:0;height:0;
  border-style:solid;
  border-width:127px 207px 0 207px;
  border-color:#c8b09a transparent transparent transparent;
}
/* Flap open state — flip upward */
.envelope.open .env-header{
  z-index:0;
  transform:rotateX(180deg);
  border-color:#8a6a4a transparent transparent transparent;
}
/* Wax seal — sits at the V-point (centre, ~65px from top of envelope) */
.env-seal{
  position:absolute;top:105px;left:50%;
  transform:translateX(-50%);
  width:54px;height:54px;
  background:radial-gradient(circle at 35% 35%,#c0150e,#6b0807);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;z-index:4;
  box-shadow:0 3px 14px rgba(0,0,0,.5),inset 0 1px 0 rgba(255,255,255,.15);
  transition:transform .4s ease,opacity .4s ease;
}
.envelope.open .env-seal{transform:translateX(-50%) scale(0);opacity:0;}
/* Letter inside envelope — clipped by .env-letter-paper-clip wrapper */
.env-letter-paper{
  position:absolute;
  bottom:0px;left:30px;right:30px;
  height:0px;
  background:linear-gradient(180deg,#fffef8,#fff9f0);
  z-index:0;
  transition:height 1s cubic-bezier(.4,0,.2,1) .4s, bottom .8s ease .4s;
  overflow:hidden;
  box-shadow:0 -2px 12px rgba(0,0,0,.15);
  display:flex;align-items:flex-start;justify-content:center;
}
.envelope.open .env-letter-paper{
  height:160px;
  bottom:80px;
}
/* Lines on the paper peeking out */
.env-letter-lines{
  width:100%;padding:16px 18px 0;
  display:flex;flex-direction:column;gap:9px;
  opacity:0;transition:opacity .4s ease .9s;
}
.envelope.open .env-letter-lines{opacity:1;}
.env-letter-line{height:5px;border-radius:3px;background:#e8d4c0;}
.env-letter-line:nth-child(1){width:80%;}
.env-letter-line:nth-child(2){width:65%;}
.env-letter-line:nth-child(3){width:75%;}
.env-letter-line:nth-child(4){width:55%;}

/* Tap hint */
.env-tap-hint{
  margin-top:28px;color:rgba(255,230,200,.7);
  font-size:.9rem;font-style:italic;letter-spacing:.04em;
  font-family:'Cormorant Garamond',serif;
  transition:opacity .4s;
}
.env-tap-hint.hidden{opacity:0;}

/* ── Stage 2: Full-screen letter ── */
.env-stage-letter{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .6s ease;
}
.env-stage-letter.show{opacity:1;pointer-events:all;}
.env-letter-full{
  background:linear-gradient(160deg,#fffef8,#fff6ee);
  border-radius:4px;
  max-width:620px;width:100%;
  max-height:90vh;
  overflow-y:auto;
  padding:52px 52px 44px;
  box-shadow:0 40px 120px rgba(0,0,0,.6);
  position:relative;
}
/* Lined paper texture */
.env-letter-full::before{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(transparent,transparent 27px,rgba(160,130,100,.12) 27px,rgba(160,130,100,.12) 28px);
  border-radius:4px;pointer-events:none;
}
.env-letter-full::after{
  content:'';position:absolute;top:0;left:72px;bottom:0;
  width:1px;background:rgba(180,100,80,.18);pointer-events:none;
}
.env-lf-deco{text-align:center;font-size:1.4rem;letter-spacing:6px;margin-bottom:20px;opacity:.6;}
.env-lf-title{
  font-family:'Playfair Display',serif;font-size:2rem;
  color:#900d09;text-align:center;margin-bottom:4px;font-style:italic;
}
.env-lf-date{font-size:.85rem;color:#a08070;text-align:center;margin-bottom:28px;font-style:italic;}
.env-lf-body{
  font-family:'Cormorant Garamond',serif;font-size:1.18rem;
  line-height:1.9;color:#2e1e14;position:relative;z-index:1;
}
.env-lf-body p{margin-bottom:16px;}
.env-lf-sig{
  text-align:right;font-family:'Playfair Display',serif;
  font-size:1.1rem;color:#900d09;margin-top:24px;font-style:italic;position:relative;z-index:1;
}
.env-lf-footer{text-align:center;font-size:.85rem;color:#a08070;margin-top:18px;font-style:italic;position:relative;z-index:1;}

/* Close button */
.env-close{
  position:fixed;top:max(18px, env(safe-area-inset-top, 0px) + 18px);right:18px;
  width:48px;height:48px;border-radius:50%;
  background:#f5ede0;border:2px solid #c8956a;
  color:#7a3a1e;font-size:1.1rem;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .15s;z-index:2300;
  box-shadow:0 3px 14px rgba(0,0,0,.35);
  -webkit-tap-highlight-color:transparent;touch-action:manipulation;
}
.env-close:hover,.env-close:active{background:#ffe8d0;transform:scale(1.08);}
@media(max-width:600px){
  .env-close{top:calc(env(safe-area-inset-top, 0px) + 56px);right:14px;width:52px;height:52px;font-size:1.2rem;}
}

/* Floating petals */
.env-petal{position:fixed;pointer-events:none;animation:envPetalFall linear forwards;}
@keyframes envPetalFall{
  0%{transform:translateY(-30px) rotate(0deg) scale(1);opacity:1;}
  80%{opacity:.8;}
  100%{transform:translateY(110vh) rotate(540deg) scale(.6);opacity:0;}
}
/* Soft ambient particles in bg */
.env-sparkle{position:fixed;pointer-events:none;border-radius:50%;animation:envSparkle ease-in-out forwards;}
@keyframes envSparkle{0%{opacity:0;transform:scale(0);}50%{opacity:.7;}100%{opacity:0;transform:scale(1.5) translateY(-40px);}}


/* ─── Mood / Requests Section ─── */
.mood-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;margin-bottom:2rem;}
.mood-card{background:#fff;border:1px solid var(--bd);border-radius:18px;padding:20px 18px;}
.mood-card-title{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--gd);margin-bottom:1rem;}
.mood-emojis{display:flex;flex-wrap:wrap;gap:8px;}
.mood-emoji{font-size:1.8rem;background:var(--gp);border:2px solid transparent;border-radius:12px;width:50px;height:50px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;}
.mood-emoji:hover,.mood-emoji.sel{border-color:var(--g);background:var(--gl);transform:scale(1.12);}
.mood-craving-btns{display:flex;flex-wrap:wrap;gap:6px;}
.mood-craving-btn{padding:7px 12px;border-radius:20px;border:1px solid var(--bd);background:var(--gp);cursor:pointer;font-size:.82rem;font-family:'Cormorant Garamond',serif;transition:all .2s;color:var(--tx);}
.mood-craving-btn:hover,.mood-craving-btn.sel{background:var(--gl);border-color:var(--g);color:var(--gd);}
.mood-message-wrap{background:#fff;border:1px solid var(--bd);border-radius:18px;padding:22px 20px;margin-bottom:1.5rem;}
.mood-submit-row{display:flex;gap:1.5rem;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-top:14px;}
.mood-label{font-size:.85rem;color:var(--txl);font-style:italic;}
.mood-who-btn{padding:8px 18px;border-radius:20px;border:2px solid var(--bd);background:var(--gp);cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:.9rem;transition:all .2s;color:var(--tx);}
.mood-who-btn.active,.mood-who-btn:hover{background:var(--gl);border-color:var(--g);color:var(--gd);}
/* Panic who buttons */
.panic-who-btn.active{box-shadow:0 0 0 3px rgba(144,13,9,.25);transform:scale(1.03);}