@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.8e0177b5.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.b97b3418.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.853070df.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist","Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.c1fdd6c2.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.799d8ef8.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.dbea232f.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono","Geist Mono Fallback"}
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-border-style:solid}}}@layer theme{:root,:host{--text-sm:.875rem;--text-base:1rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-5xl:3rem;--text-6xl:3.75rem;--text-8xl:6rem;--text-9xl:8rem;--default-font-family:var(--font-geist-sans);--default-mono-font-family:var(--font-geist-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.border{border-style:var(--tw-border-style);border-width:1px}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}:root{--background:#fff;--foreground:#171717}@media (prefers-color-scheme:dark){:root{--background:#0a0a0a;--foreground:#ededed}}body{background:var(--background);color:var(--foreground);font-family:Arial,Helvetica,sans-serif}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}
html{font-size:16px}:root{--color-bg-default:#05070f;--color-bg-elevated:#0c111f;--color-bg-gradient-start:#0f1221;--color-bg-gradient-end:#131931;--color-bg-overlay:#0f172af2;--color-bg-modal:#000c;--color-surface:#ffffff0f;--color-surface-strong:#14a3ff24;--color-surface-light:#ffffff0d;--color-border:#ffffff14;--color-border-light:#ffffff1a;--color-border-medium:#fff3;--color-text-primary:#f8fafc;--color-text-secondary:#e2e8f0b8;--color-text-tertiary:#ffffffb3;--color-text-inverse:#04070d;--text-white-strong:#fff;--text-white-base:#ffffffe6;--text-white-sub:#ffffffb3;--text-white-muted:#ffffff80;--color-accent-primary:#3b82f6;--color-accent-secondary:#f59e0b;--color-accent-danger:#ef4444;--color-accent-success:#22c55e;--color-accent-pink:#ec4899;--bg-page:#f7f7fa;--bg-panel:#fff;--border-soft:#e6e6ec;--text-main:#111;--text-sub:#666670;--text-muted:#9a9aa3;--accent:#ff4d8d;--danger:#e54848;--color-stage:radial-gradient(circle at 50% 20%,#152548 0%,#05070f 70%);--color-stage-overlay:#0b1321a6;--modal-overlay-bg:#000000b3;--modal-overlay-blur:blur(6px);--modal-overlay-z-index:100;--modal-card-bg:linear-gradient(180deg,#1a1a2e 0%,#0f1221 100%);--modal-card-border:1px solid #ffffff26;--modal-card-border-radius:1.5rem;--modal-card-shadow:0 10px 30px #0006;--modal-card-padding:2rem 1.5rem;--modal-card-max-width:22rem;--modal-card-gap:1.5rem;--modal-title-size:var(--text-2xl);--modal-title-weight:bold;--modal-title-color:var(--text-white-strong);--modal-description-size:var(--text-base);--modal-description-color:var(--text-white-sub);--modal-button-padding:.85rem 1.5rem;--modal-button-radius:999px;--modal-button-font-size:var(--text-base);--modal-button-font-weight:bold;--modal-button-primary-bg:linear-gradient(135deg,#0ea5e9 0%,#38bdf8 100%);--modal-button-primary-shadow:0 4px 15px #38bdf84d;--modal-button-secondary-bg:#ffffff0d;--modal-button-secondary-border:1px solid #ffffff1a;--modal-button-danger-bg:#ef4444cc;--modal-button-danger-shadow:0 0 20px #ef44444d;--modal-button-pink-bg:#ec4899;--modal-button-pink-shadow:0 4px 10px #ec489966;--modal-animation-duration:.3s;--modal-animation-easing:ease-out;--page-bg-gradient:linear-gradient(180deg,#0f1221 0%,#131931 100%);--page-padding-top:2rem;--page-padding-side:1.5rem;--page-padding-bottom:6rem;--page-min-height:100dvh;--container-max-width:480px;--container-gap:1.5rem;--container-padding:0;--header-gap:.75rem;--header-title-size:clamp(var(--text-3xl),4vw,var(--text-5xl));--header-title-weight:bold;--header-description-size:var(--text-base);--header-description-color:var(--text-white-sub);--card-bg:#0f172ae6;--card-border:1px solid #94a3b82e;--card-radius:1.25rem;--card-padding:1.5rem;--card-gap:1rem;--card-shadow:0 18px 45px #0f172ad9;--button-padding:.95rem 1.6rem;--button-radius:999px;--button-font-size:var(--text-base);--button-font-weight:bold;--button-gap:.75rem;--bottom-button-container-bg:linear-gradient(180deg,#0f172a33,#0f172aeb);--bottom-button-container-padding:1rem;--bottom-button-container-blur:blur(10px);--bottom-button-container-z-index:30;--font-sans:var(--font-geist-sans,"Pretendard",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif);--font-display:"Pretendard",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:var(--font-geist-mono,"JetBrains Mono",monospace);--text-xs:.75rem;--text-sm:.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--text-5xl:2.5rem;--text-6xl:3rem;--text-8xl:4rem;--text-9xl:5rem;--text-header-title:clamp(var(--text-3xl),4vw,var(--text-5xl));--text-detail-title:clamp(var(--text-3xl),4vw,var(--text-5xl));--text-memorial-date:clamp(var(--text-xl),2.6vw,var(--text-3xl));--text-icon-responsive:clamp(var(--text-3xl),20vw,var(--text-6xl));--text-icon-large:clamp(var(--text-8xl),50vw,var(--text-9xl));--app-max-width:1440px;--app-padding-inline:clamp(16px,3vw,48px);--stage-preview-size:100%;--transition-base:.16s cubic-bezier(.4,0,.2,1);--shadow-card:0 22px 45px #03060f73;--shadow-glow:0 0 35px #3b82f659;--backdrop-blur:blur(8px)}@media (prefers-color-scheme:light){:root{--color-bg-default:#f4f7fb;--color-bg-elevated:#fff;--color-surface:#0f172a14;--color-surface-strong:#3b82f62e;--color-border:#0f172a1f;--color-text-primary:#0f172a;--color-text-secondary:#0f172aad;--color-text-inverse:#fff;--color-stage:radial-gradient(circle at 50% 20%,#d6e3ff 0%,#fff 70%);--color-stage-overlay:#fafaffbf;--shadow-card:0 18px 36px #0f172a1f;--shadow-glow:0 0 35px #3b82f640}}.main-container{background:var(--color-bg-default);color:#fff;min-height:100dvh}.loading-container{color:#fff;background:#000;justify-content:center;align-items:center;min-height:100dvh;display:flex}.hub-main{background:var(--bg-page);min-height:100dvh;color:var(--text-main);padding:0;padding-top:calc(5rem + env(safe-area-inset-top));flex-direction:column;display:flex;position:relative}body:has(.pwa-install-banner) .hub-main{padding-top:calc(5rem + 3.5rem + env(safe-area-inset-top))}.hub-header-bar{height:5rem;padding:.5rem 1.5rem;padding-top:calc(.75rem + env(safe-area-inset-top));background:var(--bg-panel);border-bottom:1px solid var(--border-soft);z-index:100;justify-content:space-between;align-items:center;gap:1rem;padding-bottom:.75rem;display:flex;position:fixed;top:0;left:0;right:0}.pwa-install-banner{padding-top:calc(env(safe-area-inset-top));color:#fff;z-index:99;background:#8b5cf6;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem .75rem .5rem;display:flex;position:fixed;top:5rem;left:0;right:0;box-shadow:0 2px 8px #0000001a}.pwa-install-banner-close{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:.25rem;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;transition:background-color .2s;display:flex}.pwa-install-banner-close:hover{background:#ffffff1a}.pwa-install-banner-close:active{background:#fff3}.pwa-install-banner-content{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.pwa-install-banner-icon{color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;display:flex}.pwa-install-banner-text{color:#fff;white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:500;overflow:hidden}.pwa-install-banner-button{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:999px;flex-shrink:0;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.875rem;font-weight:700;transition:background-color .2s;display:flex}.pwa-install-banner-button:hover{background:#ffffff4d}.pwa-install-banner-button:active{background:#fff6}.pwa-install-banner-button svg{flex-shrink:0}.hub-header-profile{cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:flex-start;align-items:center;width:5rem;height:2.4rem;padding:0;display:flex}.hub-header-profile img{object-fit:cover;border:1px solid var(--border-soft);border-radius:50%;width:2.8rem;height:2.8rem}.hub-header-profile-placeholder{border:1px solid var(--border-soft);width:2.4rem;height:2.4rem;color:var(--text-sub);background:#eee;border-radius:50%;justify-content:center;align-items:center;font-size:.875rem;display:flex}.hub-header-title-section{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:.25rem;min-width:0;display:flex}.hub-header-friend-button{border:1px solid var(--border-soft);background:var(--bg-panel);height:2.4rem;color:var(--text-main);cursor:pointer;border-radius:.5rem;flex-shrink:0;justify-content:flex-end;align-items:center;padding:.5rem .75rem;font-size:.875rem;font-weight:700;display:flex}.hub-content{flex-direction:column;gap:0;width:100%;max-width:32rem;margin:0 auto;padding:0;display:flex}.hub-catchphrase{color:#8e8e98;text-align:center;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;overflow:hidden}.hub-main-title{color:var(--text-main);letter-spacing:.0625rem;text-align:center;white-space:nowrap;text-overflow:ellipsis;font-size:1.375rem;font-weight:700;overflow:hidden}.hub-game-cards{flex-direction:column;gap:0;display:flex}.hub-game-card{border:1px solid var(--border-soft);background-position:50%;background-repeat:no-repeat;background-size:cover;background-color:var(--bg-panel);border-radius:0;flex-direction:column;justify-content:space-between;width:100%;min-height:12rem;padding:1rem;display:flex;position:relative;overflow:hidden}.hub-game-card:before{content:"";z-index:1;background:linear-gradient(270deg,#0000 0%,#0000004d 40%,#00000080 60%,#000000b3 100%);position:absolute;inset:0}.hub-card-content{z-index:2;flex-direction:column;flex:1;gap:.25rem;margin-top:0;display:flex;position:relative}.hub-card-subtitle{color:var(--text-white-base);font-size:.95rem}.hub-card-title{color:var(--text-white-base);font-size:1.125rem;font-weight:700}.hub-card-description{font-size:var(--text-sm);color:var(--text-white-sub)}.hub-card-button{color:var(--text-white-base);cursor:pointer;z-index:2;background:#00000080;border:none;border-radius:999px;align-self:flex-end;margin-top:auto;padding:.625rem 1rem;font-size:.875rem;font-weight:700;position:relative}.hub-card-button:hover{background:#000000b3}.hub-card-button:disabled{color:#000000b3;cursor:not-allowed;background:#ffffff80}.hub-minigame-section{flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.hub-minigame-title{color:var(--text-main);margin:0;padding:0 1rem;font-size:1.125rem;font-weight:700}.hub-minigame-cards{flex-direction:column;gap:0;display:flex}.hub-minigame-card{border:1px solid var(--border-soft);background-position:50%;background-repeat:no-repeat;background-size:cover;background-color:var(--bg-panel);border-radius:0;flex-direction:column;justify-content:space-between;width:100%;min-height:6.4rem;padding:1rem;display:flex;position:relative;overflow:hidden}.hub-minigame-card:before{content:"";z-index:1;background:linear-gradient(270deg,#0000 0%,#0000004d 40%,#00000080 60%,#000000b3 100%);position:absolute;inset:0}.hub-minigame-card .hub-card-content,.hub-minigame-card .hub-card-button{z-index:2;position:relative}.hub-footer{background:var(--bg-panel);border-top:1px solid var(--border-soft);text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1rem;display:flex}.hub-footer-links{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}.hub-footer-link{color:var(--text-sub);padding:.25rem .5rem;font-size:.875rem;text-decoration:none}.hub-footer-link:hover{color:var(--text-main)}.hub-footer-contact{color:var(--text-sub);font-size:.875rem}.hub-footer-email{color:var(--text-sub);text-decoration:none}.hub-footer-email:hover{color:var(--text-main);text-decoration:underline}.hub-footer-copyright{color:var(--text-sub);font-size:.75rem}.friend-page-main{min-height:100dvh;padding:1.5rem;padding-bottom:calc(1.5rem + 3.75rem + env(safe-area-inset-bottom));background:var(--bg-page);color:var(--text-main);flex-direction:column;display:flex}.friend-page-container{gap:1.5rem;width:100%;max-width:50rem;margin:0 auto;display:grid}.friend-page-header{justify-content:space-between;align-items:center;display:flex}.friend-page-title{font-size:var(--text-2xl);color:var(--text-main);margin:0;font-weight:700}.friend-add-button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;padding:.75rem 1.125rem;font-size:.875rem;font-weight:700}.friend-search-input{border:1px solid var(--border-soft);width:100%;color:var(--text-main);background:#fafafa;border-radius:.75rem;padding:.875rem 1rem;font-size:.875rem;display:none}.friend-empty-message{text-align:center;color:var(--text-sub);padding:3rem}.friend-list{gap:1rem;display:grid}.friend-item{background:0 0;gap:1.5rem;padding:.25rem .5rem;display:flex}.friend-profile-image{object-fit:cover;border-radius:50%;width:4.8rem;height:4.8rem}.friend-profile-placeholder{border:1px solid var(--border-soft);width:4rem;height:4rem;color:var(--text-sub);background:#eee;border-radius:.5rem;justify-content:center;align-items:center;font-size:.875rem;display:flex}.friend-item-content{flex-direction:column;flex:1;align-self:center;gap:.5rem;display:flex}.friend-item-name{color:var(--text-main);font-size:1rem;font-weight:700}.friend-item-date{color:var(--text-sub);font-size:.8125rem;display:none}.friend-item-actions{align-items:center;gap:1rem;display:flex}.friend-edit-button{color:var(--text-main);cursor:pointer;background:#f1f1f5;border:none;border-radius:999px;padding:.5rem .75rem;font-size:.875rem;font-weight:700}.friend-edit-button:disabled{cursor:not-allowed;opacity:.5}.friend-delete-button{border:1px solid var(--danger);color:var(--danger);cursor:pointer;background:#fff;border-radius:999px;padding:.5rem .75rem;font-size:.875rem;font-weight:700}.friend-delete-button:disabled{cursor:not-allowed;opacity:.5;background:#f1f1f5}.friend-bottom-bar{padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));background:var(--bg-panel);border-top:1px solid var(--border-soft);z-index:100;position:fixed;bottom:0;left:0;right:0}.friend-bottom-bar-container{width:100%;max-width:50rem;margin:0 auto}.friend-back-button{width:100%;color:var(--text-main);cursor:pointer;background:#f1f1f5;border:none;border-radius:999px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700}.friend-form-main{min-height:100dvh;padding:1.5rem;padding-bottom:calc(1.5rem + 5rem + env(safe-area-inset-bottom));background:var(--bg-page);color:var(--text-main);flex-direction:column;align-items:center;display:flex}.friend-form-container{gap:2rem;width:100%;max-width:30rem;display:grid}.friend-form-title{font-size:var(--text-2xl);color:var(--text-main);margin:0 0 1rem;font-weight:700}.friend-form-fields{gap:1.5rem;padding:0;display:grid}.friend-form-label{color:var(--text-main);margin-bottom:.5rem;font-size:.875rem;display:block}.friend-form-label-changed{color:var(--text-sub)}.friend-form-input{border:1px solid var(--border-soft);width:100%;color:var(--text-main);background:#fafafa;border-radius:.75rem;padding:.875rem 1rem;font-size:.875rem}.friend-form-input:focus{outline:2px solid var(--accent);outline-offset:2px}.friend-form-input-file{border:1px solid var(--border-soft);width:100%;color:var(--text-sub);background:#fafafa;border-radius:.75rem;padding:.875rem 1.5rem;font-size:.875rem}.friend-form-processing{color:var(--text-sub);margin-top:.5rem;font-size:.8125rem;display:none}.friend-form-preview-label{font-size:var(--text-sm);margin-bottom:.5rem;display:none}.friend-form-preview-image{border:1px solid var(--border-soft);border-radius:50%;width:100%;max-width:14rem;height:auto;margin:1rem auto}.friend-form-error{border:1px solid var(--danger);color:var(--danger);background:#fff;border-radius:.75rem;padding:.75rem;font-size:.875rem}.friend-form-actions{padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));background:var(--bg-panel);border-top:1px solid var(--border-soft);z-index:100;gap:.75rem;max-width:30rem;margin:0 auto;display:flex;position:fixed;bottom:0;left:0;right:0}.friend-form-cancel-button{color:var(--text-main);cursor:pointer;background:#f1f1f5;border:none;border-radius:999px;flex:1;padding:.75rem 1.5rem;font-size:1rem;font-weight:700}.friend-form-cancel-button:disabled{cursor:not-allowed;opacity:.5}.friend-form-save-button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:999px;flex:1;padding:.75rem 1.5rem;font-size:1rem;font-weight:700}.friend-form-save-button:disabled{background:var(--text-muted);cursor:not-allowed;opacity:.5}.friend-form-edit-button{color:var(--text-main);cursor:pointer;background:#f1f1f5;border:none;border-radius:999px;margin:1.5rem auto 0;padding:.5rem 1rem;font-size:.875rem;font-weight:700;display:block}.friend-form-edit-button:hover{background:#e6e6ec}.crop-dialog-overlay{z-index:50;background:var(--bg-page);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);touch-action:pan-x pan-y;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;flex-direction:column;align-items:center;display:flex;position:fixed;inset:0}.crop-dialog-wrapper{flex-direction:column;width:100%;max-width:28rem;padding:1.5rem;display:flex;overflow-y:auto}.crop-dialog-content{color:var(--text-main);flex-direction:column;gap:1rem;margin-top:1rem;display:flex}.crop-dialog-header{margin-bottom:.5rem}.crop-dialog-title{font-size:var(--text-2xl);color:var(--text-main);text-align:center;margin:0;font-weight:700;display:none}.crop-dialog-controls-container{flex-direction:column;gap:.5rem;display:flex}.crop-dialog-image-container{touch-action:pan-x pan-y;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;border:1px solid var(--border-soft);background:#fafafa;border-radius:1rem;width:100%;height:20rem;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000000d}.crop-dialog-image-container .reactEasyCrop_Container{touch-action:pan-x pan-y!important;-webkit-user-select:none!important;user-select:none!important;-webkit-user-drag:none!important;justify-content:center!important;align-items:center!important;width:100%!important;height:100%!important;margin:0 auto!important;display:flex!important;position:relative!important}.crop-dialog-image-container .reactEasyCrop_CropArea{margin:auto!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.crop-dialog-image-container img{-webkit-user-select:none!important;user-select:none!important;-webkit-user-drag:none!important}.crop-dialog-cross-guide{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.crop-dialog-cross-guide-svg{width:100%;height:100%}.crop-dialog-cross-line{stroke:#0000004d;stroke-width:1px}.crop-dialog-control-group{margin-top:1rem}.crop-dialog-control-label{text-align:center;color:var(--text-main);margin-bottom:.5rem;font-size:.875rem;font-weight:700;display:block}.crop-dialog-zoom-control{justify-content:center;align-items:center;gap:.5rem;padding:0 2.4rem;display:flex}.crop-dialog-zoom-button{border:1px solid var(--border-soft);background:var(--bg-panel);width:2rem;height:2rem;color:var(--text-main);font-size:var(--text-xl);cursor:pointer;border-radius:.5rem;justify-content:center;align-items:center;transition:border-color .2s,background-color .2s,color .2s;display:flex}.crop-dialog-zoom-button:hover{border-color:var(--text-sub);background:#f1f1f5}.crop-dialog-zoom-button:active{background:#e6e6ec}.crop-dialog-zoom-slider{appearance:none;background:#e6e6ec;border-radius:.35rem;outline:none;flex:1;height:.5rem}.crop-dialog-zoom-slider::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:16px;height:16px}.crop-dialog-zoom-slider::-moz-range-thumb{background:var(--accent);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.crop-dialog-footer{z-index:50;padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));background:var(--bg-panel);border-top:1px solid var(--border-soft);position:fixed;bottom:0;left:0;right:0}.crop-dialog-footer-wrapper{max-width:28rem;font-size:var(--text-sm);gap:.75rem;margin:0 auto;font-weight:700;display:flex}.crop-dialog-button-cancel,.crop-dialog-button-confirm{cursor:pointer;border:none;border-radius:999px;flex:1;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;transition:all .2s}.crop-dialog-button-cancel{box-shadow:none;color:var(--text-main);background:#f1f1f5;border:none;font-weight:700}.crop-dialog-button-cancel:hover{background:#e6e6ec}.crop-dialog-button-cancel:disabled{opacity:.5;cursor:not-allowed}.crop-dialog-button-confirm{background:var(--accent);box-shadow:none;color:#fff}.crop-dialog-button-confirm:hover:enabled{background:#ff6ba3}.crop-dialog-button-confirm:disabled{cursor:not-allowed;opacity:.6;background:var(--text-muted)}.loading-overlay-fullscreen{z-index:99999;background:#000000e6;flex-direction:column;justify-content:center;align-items:center;gap:2rem;padding:2rem;display:flex;position:fixed;inset:0}.loading-overlay-spinner{border:3px solid #3f3f46;border-top-color:#ec4899;border-radius:50%;width:4rem;height:4rem;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.loading-overlay-message-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:3rem;display:flex}.confirm-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.confirm-modal-content{background:#1a1a2e;border:1px solid #ffffff26;border-radius:1.5rem;flex-direction:column;gap:1.5rem;width:100%;max-width:22rem;padding:2rem 1.5rem;display:flex;box-shadow:0 10px 30px #0006}.confirm-modal-title{font-size:var(--text-xl);color:var(--text-white-base);text-align:center;margin:0;font-weight:700}.confirm-modal-message{font-size:var(--text-base);color:var(--text-white-sub);text-align:center;margin:0}.confirm-modal-buttons{gap:.75rem;display:flex}.confirm-modal-button{cursor:pointer;border:none;border-radius:2rem;flex:1;padding:.75rem 1.5rem;font-size:1rem}.confirm-modal-button-cancel{color:var(--text-white-base);background:#222;border:1px solid #333}.confirm-modal-button-cancel:hover{background:#333}.confirm-modal-button-confirm{color:#fff;background:#ef4444}.confirm-modal-button-confirm:hover{background:#dc2626}.loading-overlay-message{font-size:var(--text-base);color:var(--text-white-sub);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;line-height:1.5;animation:.5s ease-in-out fadeIn;display:flex}.image-edit-loading-container{background:var(--color-bg-default);min-height:100dvh;color:var(--text-white-base);place-items:center;display:grid}.image-edit-error-container{background:var(--color-bg-default);min-height:100dvh;color:var(--text-white-base);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.image-edit-back-button{color:var(--text-white-base);cursor:pointer;font-size:var(--text-sm);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:.5rem;margin-top:1rem;padding:.5rem 1rem}.image-edit-back-button:hover{background:#ffffff1a}.legal-page{background:var(--bg-page);min-height:100dvh;color:var(--text-main);padding-top:calc(3.75rem + env(safe-area-inset-top));padding-bottom:calc(3.75rem + env(safe-area-inset-bottom));flex-direction:column;display:flex}.legal-header{z-index:10;background:var(--bg-panel);border-bottom:1px solid var(--border-soft);padding:1rem 1.5rem;padding-top:calc(1rem + env(safe-area-inset-top));justify-content:center;align-items:center;display:flex;position:fixed;top:0;left:0;right:0}.legal-header h1{color:var(--text-main);margin:0;font-size:1.375rem;font-weight:700}.legal-content{flex:1;width:100%;max-width:50rem;margin:0 auto;padding:2rem 1.5rem;overflow-y:auto}.legal-section{margin-bottom:2rem}.legal-section h2{color:var(--text-main);margin:0 0 1rem;font-size:1.125rem;font-weight:700}.legal-section p{color:var(--text-main);margin:0 0 1rem;font-size:.875rem;line-height:1.6}.legal-section ul{margin:0 0 1rem;padding-left:1.5rem;list-style-type:disc}.legal-section li{color:var(--text-main);margin-bottom:.5rem;font-size:.875rem;line-height:1.6}.legal-footer{z-index:10;background:var(--bg-panel);border-top:1px solid var(--border-soft);padding:.75rem 1.5rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));justify-content:center;display:flex;position:fixed;bottom:0;left:0;right:0}.legal-back-button{width:100%;color:var(--text-main);cursor:pointer;text-align:center;background:#f1f1f5;border:none;border-radius:999px;padding:.75rem 1.5rem;font-size:1rem;font-weight:700;text-decoration:none;display:inline-block}.legal-back-button:hover{background:#333}
