:root{--ratio: 9 / 16;--bg-base: #f5ead0;--gold: #d99a34;--ink: #69755a;--line: rgba(184, 141, 63, .86);--page-pad-v: clamp(40px, 8vh, 72px);--page-gap: clamp(24px, 5vh, 48px);--watercolor-bg: radial-gradient(ellipse 65% 56% at -4% -4%, rgba(226,181,88,.52) 0%, rgba(238,204,128,.28) 42%, transparent 68%), radial-gradient(ellipse 60% 52% at 104% -4%, rgba(220,175,80,.48) 0%, rgba(232,198,120,.24) 44%, transparent 70%), radial-gradient(ellipse 58% 50% at -4% 104%, rgba(218,170,75,.44) 0%, rgba(228,194,115,.22) 46%, transparent 72%), radial-gradient(ellipse 63% 54% at 104% 104%, rgba(224,178,85,.5) 0%, rgba(236,201,125,.26) 43%, transparent 69%), radial-gradient(ellipse 40% 36% at 50% 8%, rgba(230,185,90,.22) 0%, transparent 58%), radial-gradient(ellipse 38% 34% at 50% 92%, rgba(215,168,72,.2) 0%, transparent 60%), radial-gradient(ellipse 35% 30% at 8% 50%, rgba(228,183,88,.18) 0%, transparent 55%), radial-gradient(ellipse 37% 32% at 92% 50%, rgba(222,176,82,.2) 0%, transparent 57%), linear-gradient(145deg, rgba(242,220,150,.18) 0%, rgba(245,225,160,.12) 40%, rgba(238,210,140,.16) 100%), var(--bg-base)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;font-family:GFS Didot,Didot,serif;color:var(--ink)}body{background:var(--watercolor-bg);background-attachment:fixed}.snap-stack{height:100dvh;overflow-y:auto;scroll-snap-type:y mandatory;scroll-behavior:smooth;overscroll-behavior-y:contain}.panel{min-height:100dvh;scroll-snap-align:start;scroll-snap-stop:always;display:grid;place-items:center;position:relative}.canvas{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--page-pad-v) clamp(24px,6%,48px);gap:var(--page-gap)}@media (min-width: 600px){body{background-attachment:fixed}.panel{position:static}.canvas{position:relative;inset:auto;height:100dvh;aspect-ratio:var(--ratio);box-shadow:none}}.meta{font-family:GFS Didot,Didot,serif;font-size:calc(clamp(12px,1.55vh,18px)*.9);letter-spacing:.12em;color:var(--ink);text-align:center;line-height:1.6}.script{font-family:Playlist-Script,Great Vibes,Brush Script MT,cursive;color:var(--gold);font-weight:400;text-align:center}.btn-gold{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:#fff;border:none;border-radius:28px;padding:clamp(10px,1.5vh,16px) clamp(28px,6vw,52px);font-family:GFS Didot,Didot,serif;font-size:calc(clamp(14px,1.8vh,20px)*.9);font-weight:600;letter-spacing:.08em;cursor:pointer;text-decoration:none;transition:opacity .2s ease}.btn-gold:hover{opacity:.88}.btn-gold:disabled{opacity:.6;cursor:default}.btn-outline{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--gold);border:1.5px solid var(--gold);border-radius:28px;padding:clamp(10px,1.5vh,16px) clamp(28px,6vw,52px);font-family:GFS Didot,Didot,serif;font-size:calc(clamp(14px,1.8vh,20px)*.9);font-weight:600;letter-spacing:.08em;cursor:pointer;text-decoration:none;transition:opacity .2s ease}.btn-outline:hover{opacity:.78}.page-chip{position:fixed;right:clamp(10px,2.2vw,20px);bottom:clamp(12px,2.4vh,24px);z-index:20;background:#ffffffb8;border:1px solid rgba(184,141,63,.45);border-radius:20px;padding:4px 12px;font-family:GFS Didot,Didot,serif;font-size:calc(clamp(10px,1.3vh,14px)*.9);font-weight:600;color:var(--ink);letter-spacing:.08em;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);pointer-events:none;-webkit-user-select:none;user-select:none}.page-chip-sep{margin:0 2px;opacity:.55}.dot-nav{position:fixed;right:clamp(10px,2.2vw,20px);top:50%;transform:translateY(-50%);display:grid;gap:10px;z-index:20}.dot{width:11px;aspect-ratio:1;border-radius:50%;border:1px solid rgba(92,84,67,.5);background:#ffffffb8;cursor:pointer;transition:transform .2s ease,border-color .2s ease,background-color .2s ease}.dot:hover{transform:scale(1.1)}.dot.is-active{border-color:var(--gold);background:var(--gold)}.cover{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(6px,1.2vh,14px);text-align:center}.cover-script{font-size:calc(clamp(64px,8.4vh,112px)*.9);line-height:.86;margin:0}.cover-guest{margin-top:clamp(12px,2.4vh,28px);display:flex;flex-direction:column;gap:clamp(4px,.8vh,8px);align-items:center}.guest-name{font-size:calc(clamp(22px,2.8vh,36px)*.9);font-weight:700;letter-spacing:.06em;color:var(--ink)}.salam-block{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(12px,2.2vh,26px);text-align:center;padding:0 clamp(16px,5vw,36px)}.salam-script{font-size:calc(clamp(58px,7.6vh,104px)*.9);line-height:.86;margin:0}.salam-greeting{font-size:calc(clamp(14px,1.8vh,22px)*.9);letter-spacing:.12em;font-weight:600}.salam-text{font-size:calc(clamp(13px,1.65vh,20px)*.9);line-height:1.75;letter-spacing:.04em}.mempelai-block{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(10px,1.8vh,20px);text-align:center}.person-card{display:flex;flex-direction:column;align-items:center;gap:clamp(4px,.8vh,10px)}.person-avatar{width:clamp(64px,9vh,100px);aspect-ratio:1;border-radius:50%;border:2px solid var(--line);background:#d99a341a;overflow:hidden}.person-name{font-size:calc(clamp(34px,4.5vh,64px)*.9);line-height:.95;margin:0}.person-role{font-size:calc(clamp(10px,1.3vh,15px)*.9);letter-spacing:.22em;font-weight:600;text-transform:uppercase}.person-parents{font-size:calc(clamp(11px,1.4vh,16px)*.9);line-height:1.6;letter-spacing:.06em}.amp-sep{font-size:calc(clamp(40px,5.2vh,72px)*.9);line-height:1;margin:0}.akad-block{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(12px,2vh,24px);text-align:center}.akad-title{font-size:calc(clamp(50px,6.6vh,90px)*.9);line-height:.92;margin:0}.date-row{display:flex;align-items:center;gap:clamp(14px,2.2vw,24px)}.date-day,.date-month{font-size:calc(clamp(12px,1.55vh,19px)*.9);letter-spacing:.15em;font-weight:500;text-align:center}.date-num{font-size:calc(clamp(54px,7.2vh,96px)*.9);font-family:GFS Didot,Didot,serif;font-weight:700;color:var(--gold);line-height:1}.date-year{font-size:calc(clamp(12px,1.55vh,19px)*.9);letter-spacing:.2em;font-weight:500}.date-vline{width:1px;height:clamp(34px,4.8vh,54px);background:var(--line)}.akad-time{font-size:calc(clamp(14px,1.8vh,22px)*.9);letter-spacing:.18em}.akad-location-label{font-size:calc(clamp(10px,1.3vh,15px)*.9);letter-spacing:.28em;font-style:italic;color:var(--gold)}.akad-venue{font-size:calc(clamp(13px,1.7vh,21px)*.9);font-weight:700;letter-spacing:.1em;line-height:1.4}.akad-address{font-size:calc(clamp(11px,1.4vh,17px)*.9);letter-spacing:.12em;opacity:.78}.lokasi-block{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(12px,2vh,22px);width:100%;text-align:center}.map-frame{width:90%;aspect-ratio:4/3;border-radius:14px;overflow:hidden;border:1.5px solid var(--line)}.map-frame iframe{width:100%;height:100%;border:0}.lokasi-venue{font-size:calc(clamp(13px,1.7vh,21px)*.9);font-weight:700;letter-spacing:.1em;line-height:1.4}.lokasi-address{font-size:calc(clamp(11px,1.4vh,17px)*.9);letter-spacing:.12em;opacity:.78;margin-top:-6px}.countdown-block{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(14px,2.4vh,30px);text-align:center}.countdown-title{font-size:calc(clamp(50px,6.6vh,90px)*.9);line-height:.92;margin:0}.countdown-grid{display:flex;gap:clamp(8px,1.6vw,16px)}.countdown-box{border:1.5px solid var(--line);border-radius:10px;padding:clamp(8px,1.3vh,14px) clamp(10px,1.8vw,18px);min-width:clamp(54px,8.5vw,78px);display:flex;flex-direction:column;align-items:center;gap:3px}.countdown-num{font-size:calc(clamp(26px,3.4vh,46px)*.9);font-weight:700;color:var(--gold);font-family:GFS Didot,Didot,serif;line-height:1}.countdown-label{font-size:calc(clamp(9px,1.1vh,13px)*.9);letter-spacing:.12em;font-weight:500;text-transform:uppercase}.rsvp-text{font-size:calc(clamp(12px,1.55vh,18px)*.9);line-height:1.65;letter-spacing:.04em;max-width:82%}.quotes-block{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(20px,3.5vh,42px);text-align:center;padding:clamp(16px,3vh,36px) clamp(16px,5vw,36px)}.quotes-script{font-size:calc(clamp(52px,6.84vh,94px)*.9);line-height:1.15;margin:clamp(10px,2vh,24px) 0}.quotes-surah{font-size:calc(clamp(10px,1.3vh,15px)*.9);letter-spacing:.22em;font-style:italic;color:var(--gold);font-weight:500}.quotes-text{font-size:calc(clamp(13px,1.65vh,20px)*.9);line-height:1.8;letter-spacing:.03em;font-style:italic}.canvas--eight{justify-content:center;overflow-y:auto;padding-top:clamp(32px,5vh,56px);padding-bottom:clamp(32px,5vh,56px);gap:clamp(14px,2.2vh,24px)}.buku-tamu-block{z-index:4;display:flex;flex-direction:column;align-items:center;gap:clamp(14px,2vh,22px);width:100%;max-width:480px;text-align:center}.buku-tamu-title{font-size:calc(clamp(50px,6.6vh,90px)*.9);line-height:.92;margin:0}.buku-tamu-form{display:flex;flex-direction:column;gap:clamp(8px,1.4vh,14px);width:90%}.bt-input{width:100%;padding:clamp(9px,1.3vh,13px) clamp(12px,2vw,16px);border:1.5px solid var(--line);border-radius:10px;background:#fff9;font-family:GFS Didot,Didot,serif;font-size:calc(clamp(13px,1.6vh,16px)*.9);color:var(--ink);outline:none;transition:border-color .2s}.bt-input::placeholder{opacity:.75}.bt-input:focus{border-color:var(--gold)}.bt-textarea{resize:vertical;min-height:72px}.bt-radio-group{display:flex;gap:clamp(10px,2vw,18px);justify-content:center;flex-wrap:wrap}.bt-radio{display:flex;align-items:center;gap:5px;font-size:calc(clamp(11px,1.4vh,14px)*.9);letter-spacing:.06em;cursor:pointer;color:var(--ink)}.bt-radio input{accent-color:var(--gold)}.bt-error{font-size:calc(clamp(11px,1.4vh,14px)*.9);color:#c0392b;letter-spacing:.04em}.bt-success{font-size:calc(clamp(11px,1.4vh,14px)*.9);color:#27ae60;letter-spacing:.04em}.kartu-list{width:100%;display:flex;flex-direction:column;gap:clamp(10px,1.6vh,16px);margin-top:clamp(4px,.8vh,8px)}.kartu-item{background:#ffffffa6;border:1px solid rgba(184,141,63,.3);border-radius:14px;padding:clamp(10px,1.5vh,16px) clamp(12px,2vw,18px);text-align:left;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.kartu-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}.kartu-nama{font-weight:700;font-size:calc(clamp(12px,1.5vh,16px)*.9);color:var(--ink)}.kartu-hadir{font-size:calc(clamp(9px,1.1vh,12px)*.9);color:var(--gold);letter-spacing:.08em;white-space:nowrap}.kartu-ucapan{font-size:calc(clamp(12px,1.45vh,15px)*.9);line-height:1.65;color:var(--ink);opacity:.85;font-style:italic}.kartu-date{font-size:calc(clamp(9px,1.1vh,12px)*.9);opacity:.5;margin-top:5px;letter-spacing:.06em}.ucapan-list-header{display:flex;justify-content:right;align-items:center;margin-bottom:8px;min-height:26px}.ucapan-chip{background:#fff;border:1px solid rgba(184,141,63,.45);border-radius:20px;padding:4px 12px;font-family:GFS Didot,Didot,serif;font-size:calc(clamp(10px,1.2vh,13px)*.9);color:var(--ink);letter-spacing:.05em;cursor:pointer;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:opacity .2s}.ucapan-chip:hover{opacity:.75}.ucapan-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#00000073;display:flex;align-items:flex-end;justify-content:center;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}.ucapan-modal{background:var(--bg-base);width:100%;max-width:480px;max-height:72dvh;border-radius:20px 20px 0 0;display:flex;flex-direction:column;overflow:hidden}.ucapan-modal-header{display:flex;align-items:center;justify-content:space-between;padding:clamp(14px,2vh,20px) clamp(16px,4vw,24px) clamp(10px,1.4vh,14px);border-bottom:1px solid rgba(184,141,63,.25);flex-shrink:0}.ucapan-modal-title{font-family:GFS Didot,Didot,serif;font-size:calc(clamp(14px,1.8vh,18px)*.9);font-weight:700;letter-spacing:.08em;color:var(--ink)}.ucapan-modal-close{background:none;border:none;font-size:14px;color:var(--ink);cursor:pointer;opacity:.55;padding:4px 6px;line-height:1}.ucapan-modal-close:hover{opacity:1}.ucapan-modal-list{overflow-y:auto;padding:clamp(12px,1.8vh,18px) clamp(16px,4vw,24px);display:flex;flex-direction:column;gap:clamp(10px,1.6vh,16px)}@media (prefers-reduced-motion: reduce){.snap-stack{scroll-behavior:auto}.canvas,.dot{transition:none!important;animation:none!important}}.dt-input::placeholder{opacity:.75}
