@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Inter:wght@400;600;700&display=swap";:root{--yellow:#f4b324;--yellow-dark:#b8860b;--yellow-light:#fff8e1;--white:#fff;--ink:#111;--muted:#3d3529;--green:#388e3c;--green-bg:#edf7ee;--line:#1111111f;--shadow:0 8px 28px #3c26001f;--shadow-lg:0 16px 48px #3c26002e;--radius:20px;color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background:var(--yellow);overscroll-behavior-y:contain;min-height:100dvh}.container{max-width:480px;padding:env(safe-area-inset-top,16px) 16px calc(env(safe-area-inset-bottom,16px) + 32px);margin:auto}.landing{text-align:center;padding-top:25vh}.landing-heading{text-transform:uppercase;letter-spacing:.08em;margin:16px 0;font-family:Playfair Display,Didot,Georgia,serif;font-size:clamp(32px,8vw,48px)}.event-title{text-align:center;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);opacity:.8;-webkit-user-select:none;user-select:none;margin:8px 0;font-family:Playfair Display,Didot,Georgia,serif;font-size:13px}.hero{margin-bottom:20px}.hero h1{letter-spacing:-.02em;text-transform:uppercase;word-break:break-word;overflow-wrap:break-word;margin-bottom:14px;font-family:Playfair Display,Didot,Georgia,serif;font-size:clamp(28px,8vw,54px);line-height:1}.sub{margin-bottom:6px;font-family:Playfair Display,Didot,Georgia,serif;font-size:18px;font-style:italic}.text{color:var(--muted);font-size:15px;line-height:1.55}.steps{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:3px solid var(--yellow);margin:16px 0 22px;padding:18px 20px;position:relative}.steps-heading{text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-family:Playfair Display,Didot,serif;font-size:16px;font-weight:700}.steps-list{margin:4px 0;padding-left:22px}.steps-list li{margin:4px 0;font-size:15px}.steps p{margin:5px 0;font-size:15px}.hint{color:var(--yellow-dark);font-weight:600;margin-top:10px!important}.progress-bar-wrap{z-index:30;-webkit-backdrop-filter:blur(8px);border:2px solid var(--yellow);background:#ffffffeb;border-radius:999px;height:40px;margin-bottom:18px;position:sticky;top:0;overflow:hidden;box-shadow:0 4px 12px #00000014}.progress-bar{background:var(--green);border-radius:999px;max-width:calc(100% - 6px);transition:width .5s cubic-bezier(.4,0,.2,1);position:absolute;top:3px;bottom:3px;left:3px}.progress-label{z-index:1;height:100%;color:var(--ink);letter-spacing:.03em;justify-content:center;align-items:center;font-family:Playfair Display,serif;font-size:14px;font-weight:700;display:flex;position:relative}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:2px solid var(--yellow);margin-bottom:14px;padding:20px;transition:border-color .3s,background .3s}.card--done{border-color:var(--green);background:var(--green-bg)}.card-header{align-items:center;gap:10px;margin-bottom:8px;display:flex}.card-emoji{font-size:30px;line-height:1}.card-header h2{text-transform:uppercase;letter-spacing:.03em;flex:1;font-family:Playfair Display,Didot,Georgia,serif;font-size:24px}.card-check{background:var(--green);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:16px;font-weight:700;animation:.35s cubic-bezier(.175,.885,.32,1.275) pop;display:flex}.card p{margin:4px 0;font-size:15px;line-height:1.45}.card small{color:var(--muted);font-size:13px;font-style:italic;line-height:1.4}.completed-msg{text-align:center;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:2px solid var(--yellow);margin-top:8px;padding:28px 20px}.completed-msg p{margin-top:10px;font-size:16px;font-weight:600;line-height:1.5}.credit{text-align:center;color:var(--muted);opacity:.5;letter-spacing:.05em;margin-top:32px;font-size:11px}.name-section{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:2px solid var(--yellow);margin-top:20px;padding:24px 20px}.name-label{text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-family:Playfair Display,Didot,serif;font-size:20px;font-weight:700;display:block}.name-hint{color:var(--muted);margin-bottom:16px;font-size:14px;line-height:1.4}.name-input{border:1px solid var(--line);border-radius:14px;width:100%;margin-bottom:14px;padding:14px 16px;font-family:inherit;font-size:18px;transition:border-color .2s}.name-input:focus{border-color:var(--yellow);outline:none}.actions{gap:10px;margin-top:14px;display:flex}button{background:var(--ink);color:var(--white);letter-spacing:.03em;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none;border:none;border-radius:999px;justify-content:center;align-items:center;gap:7px;padding:13px 20px;font-family:Playfair Display,serif;font-size:15px;font-weight:600;transition:transform .12s,opacity .12s;display:inline-flex}button:active{transform:scale(.95)}button:disabled{opacity:.45;cursor:not-allowed;transform:none}.secondary{color:var(--ink);background:#f0f0f0}.btn-icon{color:var(--muted);background:0 0;border-radius:50%;padding:8px}.btn-icon:active{background:#0000000d}.btn-icon-label{color:var(--ink);background:#f0f0f0;border-radius:50%;padding:10px}.modal{z-index:50;background:#0000008c;justify-content:center;align-items:flex-end;padding:16px;animation:.2s fade-in;display:flex;position:fixed;inset:0}.modal-box{background:var(--white);border-radius:var(--radius);-webkit-overflow-scrolling:touch;width:100%;max-width:420px;max-height:85dvh;padding:22px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.modal-header h3{text-transform:uppercase;letter-spacing:.03em;font-family:Playfair Display,Didot,Georgia,serif;font-size:22px}.modal-desc{color:var(--muted);margin-bottom:18px;font-size:14px;line-height:1.4}.btn-full{width:100%;margin-bottom:10px}.btn-cancel{color:var(--muted);border:1px solid var(--line);background:0 0;margin-bottom:0}.btn-primary{background:var(--yellow);color:var(--ink);padding:15px 20px;font-size:16px}.preview-wrap{margin-bottom:4px}.preview-img{object-fit:cover;border-radius:14px;width:100%;max-height:280px;margin-bottom:14px;animation:.3s pop}.preview-actions{flex-direction:column;display:flex}.uploading{color:var(--muted);justify-content:center;align-items:center;gap:10px;padding:22px 0;font-weight:600;display:flex}.toast{top:calc(env(safe-area-inset-top,16px) + 8px);background:var(--green);color:#fff;z-index:100;box-shadow:var(--shadow-lg);pointer-events:none;border-radius:999px;align-items:center;gap:8px;padding:12px 22px;font-size:14px;font-weight:700;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:fixed;left:50%;transform:translate(-50%)translateY(-200%)}.toast--show{transform:translate(-50%)translateY(0)}.celebration-overlay{z-index:90;pointer-events:none;background:#00000080;justify-content:center;align-items:center;animation:5s both celebration-fade;display:flex;position:fixed;inset:0}.celebration-content{text-align:center;background:var(--white);box-shadow:var(--shadow-lg);border-radius:28px;padding:48px 40px;animation:.6s cubic-bezier(.175,.885,.32,1.275) both celebration-pop}.celebration-emoji{font-size:100px;animation:.8s both celebration-bounce;display:block}.celebration-text{text-transform:uppercase;letter-spacing:.1em;color:var(--ink);margin-top:12px;font-family:Playfair Display,serif;font-size:42px;font-weight:700}.confetti-piece{border-radius:2px;width:10px;height:10px;position:absolute}.confetti-round{border-radius:50%;width:8px;height:8px}@keyframes celebration-fade{0%,60%{opacity:1}to{opacity:0}}@keyframes celebration-pop{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes celebration-bounce{0%{transform:scale(0)rotate(-20deg)}50%{transform:scale(1.3)rotate(10deg)}70%{transform:scale(.9)rotate(-5deg)}to{transform:scale(1)rotate(0)}}.error{color:#d32f2f;background:#ffeaea;border-radius:12px;margin:8px 0;padding:10px 14px;font-size:14px;font-weight:600}.admin{max-width:720px;margin:auto;padding:20px 16px 40px}.admin h1{text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px;font-family:Playfair Display,Didot,Georgia,serif}.admin .text{margin-bottom:20px}.admin-form{flex-direction:column;gap:12px;max-width:400px;display:flex}.admin input{border:1px solid var(--line);border-radius:14px;width:100%;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .2s}.admin input:focus{border-color:var(--yellow);outline:none}.admin-meta{color:var(--muted);font-size:13px}.admin-status{color:var(--muted);margin-top:10px;font-size:14px;font-weight:600}.admin-top-bar{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.admin-top-actions{align-items:center;gap:8px;display:flex}.btn-zip{background:var(--ink);color:var(--white);white-space:nowrap;padding:10px 16px;font-size:14px}.admin-progress-section{margin-bottom:16px}.admin-progress-wrap{background:var(--line);border-radius:999px;height:6px;margin-bottom:6px;overflow:hidden}.admin-progress-bar{background:var(--yellow);border-radius:999px;height:100%;transition:width .3s}.admin-section{margin-bottom:28px}.admin-section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.admin-section-header h2{text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:8px;font-family:Playfair Display,Didot,Georgia,serif;font-size:22px;display:flex}.admin-count{color:var(--muted);text-transform:none;font-size:14px;font-weight:400}.btn-category-zip{color:var(--muted);background:#f0f0f0;border-radius:10px;padding:8px 10px;font-size:12px}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px;display:grid}.gallery-thumb{aspect-ratio:1;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#f5f5f5;border:none;border-radius:10px;padding:0;position:relative;overflow:hidden}.thumb-img{object-fit:cover;width:100%;height:100%;display:block}.thumb-placeholder{width:100%;height:100%;color:var(--muted);justify-content:center;align-items:center;font-size:14px;display:flex}.gallery-zoom{color:#fff;opacity:0;background:#00000073;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;transition:opacity .2s;display:flex;position:absolute;bottom:22px;right:4px}.thumb-name{color:#fff;text-align:center;white-space:nowrap;text-overflow:ellipsis;background:#0009;padding:2px 4px;font-family:Inter,system-ui,sans-serif;font-size:10px;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.gallery-thumb:hover .gallery-zoom,.gallery-thumb:focus-visible .gallery-zoom{opacity:1}@media (hover:none){.gallery-zoom{opacity:.6}}.viewer-overlay{z-index:60;background:#000000f0;justify-content:center;align-items:center;animation:.2s fade-in;display:flex;position:fixed;inset:0}.viewer-content{flex-direction:column;width:100%;height:100%;display:flex}.viewer-toolbar{padding:env(safe-area-inset-top,12px) 12px 12px;flex-shrink:0;justify-content:space-between;display:flex}.viewer-btn{color:#fff;background:#ffffff1f;width:44px;height:44px}.viewer-btn:active{background:#ffffff40}.viewer-img{object-fit:contain;width:100%;min-height:0;padding:0 16px calc(env(safe-area-inset-bottom,16px) + 16px);flex:1}.viewer-loading{color:#fff9;flex:1;justify-content:center;align-items:center;display:flex}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes pop{0%{transform:scale(0)}70%{transform:scale(1.15)}to{transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:.5s both fade-in}.fade-in-up{animation:.5s both fade-in-up}.slide-up{animation:.35s cubic-bezier(.175,.885,.32,1.275) both slide-up}.spin{animation:1s linear infinite spin}@media (width<=480px){.actions{flex-direction:column}.actions button{width:100%}.admin-top-bar{flex-direction:column}.admin-top-actions{justify-content:flex-end;width:100%}.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media (width>=481px){.container{padding:24px}.modal{align-items:center}.modal-box{max-height:90dvh}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}.confetti-canvas{display:none}}
