@import "https://fonts.googleapis.com/css2?family=Alegreya+Sans:wght@400;700;900&family=Caveat:wght@400;700&family=Commissioner:wght@400;700;900&family=GFS+Didot&family=GFS+Neohellenic:wght@400;700&family=Great+Vibes&family=Klee+One:wght@400;600&family=Manrope:wght@400;700;800&family=Mansalva&family=Montserrat:wght@400;600;800&family=Mynerve&family=Noto+Sans:wght@400;700;900&family=Noto+Serif:wght@400;700;900&family=Open+Sans:wght@400;700;800&family=Poppins:wght@400;600;800&family=Roboto:wght@400;700;900&family=Roboto+Slab:wght@400;700;900&family=Ubuntu:wght@400;700&display=swap";@import "https://db.onlinewebfonts.com/c/f2a83bfa8c89b182bf95e5d9e7ff3414?family=CYN_Gamp";@import "https://db.onlinewebfonts.com/c/dd08367b8fe6c0458c5e73341061e579?family=PVF_Sincerely";*{box-sizing:border-box}body{color:#172026;background:#f4f7f8;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh}.topbar{background:#fff;border-bottom:1px solid #d9e2e4;justify-content:space-between;align-items:center;padding:22px 28px;display:flex}.eyebrow{color:#0f766e;letter-spacing:0;text-transform:uppercase;margin-bottom:4px;font-size:.76rem;font-weight:800;display:block}h1,h2,p{margin:0}.topbar h1{max-width:760px;font-size:clamp(1.45rem,2.5vw,2.5rem);line-height:1.05}.workspace{grid-template-columns:minmax(260px,340px) minmax(380px,1fr) minmax(260px,320px);gap:18px;padding:18px;display:grid}.panel{background:#fff;border:1px solid #d9e2e4;border-radius:8px;padding:18px}.panel h2{margin-bottom:14px;font-size:1rem}.editor-panel{gap:13px;display:grid}label{color:#4b5563;gap:6px;font-size:.78rem;font-weight:700;display:grid}input,select,textarea{color:#111827;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;width:100%;min-height:40px;padding:9px 10px}textarea{resize:vertical;min-height:86px}.control-group{gap:8px;display:grid}.control-group>span{color:#4b5563;font-size:.78rem;font-weight:800}.actions-row{flex-wrap:wrap;gap:8px;display:flex}.actions-row button,.primary-action,.text-button,.picker-button{border:1px solid #cbd5e1;border-radius:6px;justify-content:center;align-items:center;gap:7px;min-height:38px;padding:8px 11px;display:inline-flex}.actions-row button,.picker-button{color:#172026;background:#fff}.email-row{grid-template-columns:minmax(0,1fr) auto;gap:8px;width:min(100%,640px);max-width:640px;display:grid}.email-row button{color:#172026;background:#fff;border:1px solid #cbd5e1;border-radius:6px;justify-content:center;align-items:center;gap:7px;min-height:40px;padding:9px 12px;font-weight:800;display:inline-flex}.event-list button.active{border-color:#0f766e;box-shadow:0 0 0 2px #0f766e21}.picker-button{text-align:left;justify-content:space-between;width:100%;min-height:54px}.picker-copy,.picker-visual{align-items:center;display:flex}.picker-copy{flex-direction:column;align-items:flex-start;gap:3px;min-width:0}.picker-copy span{color:#64748b;font-size:.74rem;font-weight:800}.picker-copy strong{color:#111827;text-overflow:ellipsis;white-space:nowrap;width:100%;font-size:.94rem;overflow:hidden}.picker-visual{color:#64748b;flex:none;gap:8px}.picker-swatch{border:1px solid #0f172a33;border-radius:999px;width:28px;height:28px;display:inline-block}.primary-action{color:#fff;background:#0f766e;border-color:#0f766e;font-weight:800}.primary-action:disabled,.actions-row button:disabled{cursor:not-allowed;opacity:.55}.preview-column{flex-direction:column;align-items:center;gap:14px;min-width:0;display:flex}.invitation{aspect-ratio:210/297;width:min(100%,640px);max-width:640px;position:relative;overflow:hidden;box-shadow:0 24px 70px #0f172a29}.invite-image{touch-action:none;-webkit-user-select:none;user-select:none;background:#dbeafe;justify-content:center;align-items:center;height:34%;display:flex;position:relative;overflow:hidden}.invite-image img{object-fit:cover;pointer-events:none;width:100%;height:100%}.invite-image.editable{cursor:grab}.invite-image.editable:active{cursor:grabbing}.drag-hint{color:#fff;pointer-events:none;background:#0f172ab8;border-radius:999px;padding:5px 10px;font-family:Inter,sans-serif;font-size:.72rem;font-weight:800;position:absolute;bottom:14px;left:50%;transform:translate(-50%)}.curve{border-radius:50% 50% 0 0;height:78px;position:absolute;top:29%;left:-8%;right:-8%}.invite-body{text-align:center;z-index:1;flex-direction:column;align-items:center;gap:15px;padding:34px 44px 28px;display:flex;position:relative}.invite-icon{background:#ffffffb8;border:1px solid;border-radius:999px;justify-content:center;align-items:center;width:58px;height:58px;display:flex}.invite-type{letter-spacing:0;text-transform:uppercase;font-family:Inter,sans-serif;font-size:.82rem;font-weight:900}.invite-body h2{max-width:100%;font-size:clamp(2rem,6vw,4rem);line-height:.95}.hosted,.invite-message{font-family:Inter,sans-serif}.hosted{color:#4b5563;font-size:.98rem}.invite-details{gap:8px;width:100%;display:grid}.invite-details span{color:#263238;justify-content:center;align-items:center;gap:7px;display:inline-flex}.invite-message{color:#374151;max-width:430px;line-height:1.5}.qr-line{background:#ffffffa8;border:1px solid #0f172a1a;border-radius:8px;align-items:center;gap:14px;width:min(100%,390px);margin-top:4px;padding:12px;display:flex}.qr-line img{width:82px;height:82px}.qr-line p{text-align:left;font-family:Inter,sans-serif;font-size:.82rem}.status{color:#0f766e;font-size:.9rem;font-weight:700}.event-list{gap:8px;margin-bottom:16px;display:grid}.event-list button{text-align:left;background:#f8fafc;border:1px solid #d9e2e4;border-radius:6px;gap:4px;padding:10px;display:grid}.event-list span{color:#64748b;font-size:.78rem}.qr-box{word-break:break-word;border-bottom:1px solid #d9e2e4;gap:8px;margin-bottom:16px;padding-bottom:16px;display:grid}.qr-box img{border:1px solid #d9e2e4;border-radius:8px;width:100%}.qr-box a{color:#0f766e;font-size:.84rem}.download-link,.gallery-actions a,.gallery-actions button{color:#172026;background:#fff;border:1px solid #cbd5e1;border-radius:6px;justify-content:center;align-items:center;gap:7px;min-height:38px;padding:8px 11px;font-size:.9rem;font-weight:800;text-decoration:none;display:inline-flex}.guest-page{align-items:center;min-height:100vh;padding:24px;display:flex}.guest-upload{text-align:center;background:#ffffffe0;border:1px solid #0f172a1f;border-radius:8px;gap:16px;width:100%;max-width:520px;margin:auto;padding:28px;display:grid}.guest-heading{justify-items:center;gap:8px;display:grid}.guest-heading span{color:#64748b;text-transform:uppercase;font-size:.78rem;font-weight:900}.guest-heading h1{font-size:clamp(2rem,7vw,3.5rem);line-height:1}.guest-heading p{color:#475569;line-height:1.5}.dropzone{color:#334155;border:2px dashed #94a3b8;border-radius:8px;place-items:center;min-height:190px;padding:22px;display:grid;position:relative}.dropzone input{opacity:0;position:absolute;inset:0}.guest-capture-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.capture-button{color:#334155;text-align:center;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;align-content:center;place-items:center;gap:7px;min-height:132px;padding:16px;display:grid;position:relative}.capture-button.wide{grid-column:1/-1;min-height:110px}.camera-mode-button{color:#0f766e;border-color:#0f766e}.capture-button strong{color:#111827;font-size:.98rem}.capture-button span{color:#64748b;font-size:.78rem}.capture-button input{cursor:pointer;opacity:0;position:absolute;inset:0}.upload-note{color:#64748b;font-size:.86rem;line-height:1.45}.camera-overlay{z-index:30;background:#0f172a;padding:0;position:fixed;inset:0}.event-camera-panel{color:#fff;background:#0f172a;grid-template-rows:auto minmax(0,1fr) auto;width:100vw;height:100dvh;padding:14px;display:grid;overflow:hidden}.event-camera-panel header{z-index:2;background:#0f172adb;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;display:flex;position:relative}.event-camera-panel h2{color:#fff;font-size:1.1rem}.event-camera-panel header button{color:#fff;background:#ffffff1f;border:1px solid #ffffff47;border-radius:6px;justify-content:center;align-items:center;width:38px;height:38px;display:inline-flex}.camera-preview{background:#0f172a;border-radius:0;position:relative;overflow:hidden}.camera-preview video{object-fit:cover;width:100%;height:100%;display:block}.camera-preview span{color:#fff;background:#0f172ab8;border-radius:999px;padding:6px 11px;font-size:.82rem;font-weight:800;position:absolute;bottom:18px;left:50%;transform:translate(-50%)}.camera-controls{z-index:2;background:#0f172adb;border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;padding:12px;display:grid;position:relative}.camera-controls button{color:#fff;background:#ffffff1f;border:1px solid #ffffff4d;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:56px;padding:12px;font-weight:900;display:inline-flex}.camera-controls button.recording{color:#fff;background:#be123c;border-color:#be123c}.gallery-page{min-height:100vh;padding:22px}.gallery-topbar{background:#fff;border:1px solid #d9e2e4;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;padding:18px;display:flex}.gallery-topbar h1{font-size:clamp(1.5rem,3vw,2.6rem);line-height:1}.gallery-topbar p{color:#64748b;margin-top:6px}.gallery-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:8px;display:flex}.thumbnail-toggle{color:#334155;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;align-items:center;gap:8px;min-height:38px;padding:8px 11px;font-size:.9rem;font-weight:800;display:inline-flex}.thumbnail-toggle input{accent-color:#0f766e;width:16px;min-height:16px}.media-grid-page{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;display:grid}.media-card{background:#fff;border:1px solid #d9e2e4;border-radius:8px;overflow:hidden}.media-preview,.media-placeholder{aspect-ratio:4/3;background:#e2e8f0;width:100%;display:block}.media-preview{object-fit:cover}.media-placeholder{color:#64748b;flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.media-placeholder span{color:#334155;font-size:.82rem;font-weight:800}.media-card div{gap:4px;padding:10px;display:grid}.media-card strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.media-card span{color:#64748b;font-size:.8rem}.text-button{color:#475569;background:0 0;border:0}.secondary-action{color:#172026;background:#fff;border:1px solid #cbd5e1;border-radius:6px;justify-content:center;align-items:center;min-height:40px;padding:9px 12px;font-weight:800;display:inline-flex}.modal-backdrop{z-index:20;background:#0f172a73;justify-content:center;align-items:center;padding:22px;display:flex;position:fixed;inset:0}.picker-modal{background:#fff;border:1px solid #0f172a26;border-radius:8px;gap:16px;width:min(100%,760px);max-width:760px;max-height:min(760px,92vh);padding:18px;display:grid;overflow:auto;box-shadow:0 26px 80px #0f172a3d}.modal-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.modal-header h2{font-size:1.05rem}.modal-header button{color:#334155;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;justify-content:center;align-items:center;width:36px;height:36px;display:inline-flex}.font-options{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.font-options button{color:#111827;text-align:left;background:#f8fafc;border:1px solid #d9e2e4;border-radius:8px;gap:6px;min-height:88px;padding:14px;display:grid}.font-options button.selected,.large-swatches button.selected,.icon-picker-grid button.selected{border-color:#0f766e;box-shadow:0 0 0 3px #0f766e24}.font-options strong{font-size:1.12rem}.font-options span{color:#64748b;font-size:1.35rem;line-height:1}.color-picker{gap:16px;display:grid}.large-swatches{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;display:grid}.large-swatches button{aspect-ratio:1;border:1px solid #0f172a29;border-radius:8px;justify-content:center;align-items:end;padding:9px;display:flex}.large-swatches span{color:#334155;background:#ffffffb8;border-radius:999px;padding:3px 7px;font-size:.7rem;font-weight:800}.color-input-row{background:#f8fafc;border:1px solid #d9e2e4;border-radius:8px;padding:12px}.color-input-row span{grid-template-columns:64px 1fr;align-items:center;gap:10px;display:grid}.color-input-row input[type=color]{height:42px;min-height:42px;padding:3px}.icon-picker-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;display:grid}.icon-picker-grid button{color:#172026;background:#f8fafc;border:1px solid #d9e2e4;border-radius:8px;place-items:center;gap:8px;min-height:92px;padding:12px 8px;display:grid}.icon-picker-grid span{color:#475569;font-size:.78rem;font-weight:800}.image-crop-controls{gap:14px;display:grid}.image-crop-controls p{color:#475569;line-height:1.45}.range-control{background:#f8fafc;border:1px solid #d9e2e4;border-radius:8px;padding:12px}.range-control span{justify-content:space-between;align-items:center;display:flex}.range-control strong{color:#0f766e;font-size:.86rem}.range-control input[type=range]{accent-color:#0f766e;background:0 0;border:0;min-height:28px;padding:0}@media (width<=1120px){.workspace{grid-template-columns:320px 1fr}.events-panel{grid-column:1/-1}}@media (width<=760px){.topbar{flex-direction:column;align-items:flex-start;gap:14px}.workspace{grid-template-columns:1fr;padding:12px}.invite-body{gap:10px;padding:22px 22px 20px}.qr-line{flex-direction:column;align-items:center}.qr-line p{text-align:center}.email-row{grid-template-columns:1fr}.gallery-topbar{flex-direction:column;align-items:flex-start}.gallery-actions{justify-content:flex-start;width:100%}.font-options,.large-swatches,.icon-picker-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
