@import url("https://fonts.googleapis.com/css2?family=Great+Vibes&display=swap");*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }

/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}body{--tw-bg-opacity:1;background-color:rgb(250 250 250/var(--tw-bg-opacity,1));font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-\[60\]{z-index:60}.mx-auto{margin-left:auto;margin-right:auto}.ml-2{margin-left:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.hidden{display:none}.w-\[190px\]{width:190px}.min-w-0{min-width:0}.max-w-\[520px\]{max-width:520px}.shrink-0{flex-shrink:0}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-b-lg{border-bottom-right-radius:.5rem;border-bottom-left-radius:.5rem}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-white\/10{border-color:hsla(0,0%,100%,.1)}.bg-black\/30{background-color:rgba(0,0,0,.3)}.bg-black\/60{background-color:rgba(0,0,0,.6)}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.bg-white\/10{background-color:hsla(0,0%,100%,.1)}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-\[11px\]{font-size:11px}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.text-amber-200\/90{color:hsla(48,97%,77%,.9)}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/60{color:hsla(0,0%,100%,.6)}.text-white\/70{color:hsla(0,0%,100%,.7)}.text-white\/90{color:hsla(0,0%,100%,.9)}.opacity-0{opacity:0}.opacity-100{opacity:1}.outline-none{outline:2px solid transparent;outline-offset:2px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur:blur(8px);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-500{transition-duration:.5s}:root{--bg-primary:#2a2520;--bg-secondary:#3d3630;--bg-warm:#f5f0e8;--bg-paper:#faf7f2;--bg-paper-creamy:#f8f4ed;--bg-paper-lines:hsla(36,14%,66%,.25);--text-primary:#f5f0e8;--text-secondary:#b8b0a4;--text-dark:#2a2520;--text-ink:#2b416a;--accent:#5c4033;--accent-hover:#7a5a4a;--accent-muted:#8b7355;--shadow-soft:0 2px 8px rgba(0,0,0,.12);--shadow-medium:0 4px 16px rgba(0,0,0,.15);--shadow-strong:0 8px 32px rgba(0,0,0,.2);--shadow-bubble:0 2px 12px rgba(0,0,0,.1);--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-bubble:18px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--font-ui:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-handwriting:"Caveat",cursive;--line-height-ruled:27px;--max-width:430px}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-ui);background:var(--bg-primary);color:var(--text-primary);line-height:1.5}#root,body{min-height:100vh}#root{display:flex;justify-content:center}.app-container{width:100%;max-width:var(--max-width);min-height:100vh;background:var(--bg-primary);position:relative;overflow-x:hidden}button{font-family:var(--font-ui);cursor:pointer;border:none;background:none;color:inherit}button:focus{outline:2px solid var(--accent);outline-offset:2px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--accent-muted);border-radius:4px}.message{margin-bottom:200px;max-width:88%;margin-left:0;position:relative;display:flex;flex-direction:column;align-items:flex-start}@media (min-width:520px){.message{max-width:82%;margin-left:2px}}.message__time{font-family:var(--font-ui);font-size:11px;font-weight:500;color:hsla(0,0%,100%,.6);margin-bottom:var(--space-xs);margin-left:var(--space-sm);letter-spacing:.3px}.message__meta{right:14px;font-family:var(--font-ui);font-weight:600;color:rgba(0,0,0,.45);letter-spacing:.2px}.message__meta,.message__meta--photo{position:absolute;bottom:10px;font-size:11px}.message__meta--photo{right:10px;padding:4px 10px;border-radius:999px;background:rgba(0,0,0,.45);color:hsla(0,0%,100%,.9)}.message__bubble{position:relative;display:inline-flex;flex-direction:column;width:-moz-fit-content;width:fit-content;max-width:min(86vw,520px);white-space:pre-wrap;word-break:break-word;background:var(--bg-paper-creamy);background-image:radial-gradient(circle at 20% 20%,rgba(0,0,0,.02) 0 2px,transparent 2px),radial-gradient(circle at 80% 50%,rgba(0,0,0,.02) 0 2px,transparent 2px),linear-gradient(180deg,hsla(0,0%,100%,.06),rgba(0,0,0,.02));background-size:140px 140px,180px 180px,auto;background-repeat:repeat;background-blend-mode:multiply;border-radius:var(--radius-bubble);border-bottom-left-radius:var(--space-xs);overflow:visible;box-shadow:var(--shadow-bubble)}.message__bubble:after{content:"";position:absolute;bottom:0;left:-8px;width:12px;height:12px;background:var(--bg-paper-creamy);clip-path:polygon(100% 0,100% 100%,25% 100%,80% 0)}.message__bubble--photo{overflow:hidden;border-radius:var(--radius-bubble);border-bottom-left-radius:var(--space-xs);cursor:pointer;width:200px;max-width:100%}.message__bubble--photo:after{display:none}.message__image{width:200px;height:200px;max-width:100%;display:block;border-radius:var(--radius-bubble);border-bottom-left-radius:var(--space-xs);-o-object-fit:cover;object-fit:cover}.message__photo-count{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.55);color:#fff;padding:4px 10px;border-radius:999px;font-family:var(--font-ui);font-size:12px;letter-spacing:.2px}.message__bubble--grid{padding:0}.message__photo-grid{display:grid;gap:2px;border-radius:var(--radius-bubble);border-bottom-left-radius:var(--space-xs);overflow:hidden}.message__photo-grid,.message__photo-grid--2,.message__photo-grid--3{grid-template-columns:repeat(2,1fr)}.message__photo-grid--3{grid-template-rows:auto auto}.message__photo-grid--3 .message__photo-grid-item:first-child{grid-column:1/3}.message__photo-grid--4{grid-template-columns:repeat(2,1fr)}.message__photo-grid-item{position:relative;aspect-ratio:1}.message__photo-grid--3 .message__photo-grid-item:first-child{aspect-ratio:2/1}.message__grid-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.message__photo-grid-more{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-ui);font-size:20px;font-weight:600}.message__caption-bubble{position:relative;margin-top:var(--space-sm);padding:calc(var(--space-md) - 2px) var(--space-lg);background:var(--bg-paper-creamy);background-image:radial-gradient(circle at 20% 20%,rgba(0,0,0,.02) 0 2px,transparent 2px),radial-gradient(circle at 80% 50%,rgba(0,0,0,.02) 0 2px,transparent 2px),linear-gradient(180deg,hsla(0,0%,100%,.06),rgba(0,0,0,.02));background-size:140px 140px,180px 180px,auto;background-repeat:repeat;background-blend-mode:multiply;border-radius:var(--radius-bubble);border-bottom-left-radius:var(--space-xs);box-shadow:var(--shadow-bubble)}.message__caption-bubble:after{content:"";position:absolute;bottom:0;left:-8px;width:12px;height:12px;background:var(--bg-paper-creamy);clip-path:polygon(100% 0,100% 100%,25% 100%,80% 0)}.message__caption{font-family:var(--font-handwriting);font-size:20px;line-height:var(--line-height-ruled);color:var(--text-ink)}.deterrent-content{-moz-user-select:none;user-select:none;-webkit-user-select:none}.deterrent-media-guard{position:absolute;inset:0;background:transparent;z-index:2;cursor:pointer}.date-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;margin:var(--space-md) auto var(--space-sm);border-radius:999px;font-family:var(--font-ui);font-size:12px;font-weight:600;color:rgba(0,0,0,.65);background:hsla(0,0%,100%,.8);width:-moz-fit-content;width:fit-content;box-shadow:var(--shadow-soft)}.date-pill--overlay{background:hsla(0,0%,100%,.14);color:hsla(0,0%,100%,.9);border:1px solid hsla(0,0%,100%,.18);backdrop-filter:blur(8px)}.date-pill--paper{background:rgba(0,0,0,.06);color:var(--text-dark);border:1px solid rgba(0,0,0,.06);box-shadow:none}.feed-item{position:relative}.sticky-date{position:fixed;top:76px;left:50%;transform:translateX(-50%);padding:6px 14px;border-radius:999px;background:rgba(0,0,0,.45);color:#fff;font-family:var(--font-ui);font-size:12px;font-weight:700;z-index:30;border:1px solid hsla(0,0%,100%,.1);backdrop-filter:blur(8px)}.message__bubble--text{padding:calc(var(--space-md) - 2px) var(--space-lg) calc(var(--space-md) + 10px);background:var(--bg-paper-creamy)}.message__handwriting{font-size:22px;line-height:var(--line-height-ruled);word-break:break-word;white-space:pre-wrap}.message__handwriting,.message__warm-intro{font-family:var(--font-handwriting);color:var(--text-ink)}.message__warm-intro{font-size:20px;margin-bottom:var(--space-sm);opacity:.8}.actions{display:flex;gap:var(--space-md);padding:var(--space-sm) 0;margin-top:var(--space-sm);margin-left:var(--space-xs)}.actions__btn{display:flex;align-items:center;gap:6px;font-family:var(--font-ui);font-size:12px;font-weight:500;color:hsla(0,0%,100%,.6);transition:color .2s,transform .15s;padding:6px 10px;border-radius:var(--radius-sm);background:hsla(0,0%,100%,.08)}.actions__btn:hover{color:var(--text-primary);background:hsla(0,0%,100%,.12)}.actions__btn:active{transform:scale(.96)}.actions__btn--active{color:var(--accent-muted);background:hsla(0,0%,100%,.12)}.actions__icon{width:16px;height:16px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none}.message__reaction{margin-top:var(--space-sm);margin-left:var(--space-xs);font-size:20px}.message__bubble--poll{padding:var(--space-md) var(--space-lg) calc(var(--space-md) + 10px)}.poll__question{font-family:var(--font-ui);font-size:14px;font-weight:600;color:rgba(43,65,106,.9);margin-bottom:var(--space-sm)}.poll__options{display:flex;flex-direction:column;gap:8px;padding-right:8px}.poll__option{width:100%;text-align:left;padding:8px 10px;border-radius:var(--radius-sm);background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.06);font-family:var(--font-ui);font-size:13px;font-weight:500;color:rgba(43,65,106,.85)}.poll__option:active{transform:scale(.99)}.emoji-panel{display:grid;grid-auto-flow:column;grid-template-rows:repeat(2,1fr);grid-auto-columns:48px;gap:12px;padding:14px 18px;background:var(--bg-secondary);border-radius:var(--radius-lg);margin-top:var(--space-sm);box-shadow:var(--shadow-medium);min-height:120px;overflow-x:auto;align-items:center}.emoji-panel__btn{font-size:22px;padding:var(--space-xs);border-radius:var(--radius-sm);transition:transform .2s,background .2s;line-height:1;height:100%;width:100%;display:flex;align-items:center;justify-content:center}.emoji-panel__btn:hover{transform:scale(1.15);background:hsla(0,0%,100%,.1)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);max-width:100%;max-height:90vh;overflow:auto;box-shadow:var(--shadow-strong)}.modal__close{position:absolute;top:var(--space-md);right:var(--space-md);width:40px;height:40px;border-radius:50%;background:hsla(0,0%,100%,.15);backdrop-filter:blur(8px);font-size:18px;color:var(--text-primary);display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:20}.modal__close:hover{background:hsla(0,0%,100%,.25)}.modal__close--light{background:hsla(0,0%,100%,.14)}.modal-overlay--photo{padding:0;background:rgba(0,0,0,.92)}.photo-viewer{position:fixed;inset:0;z-index:1200;background:rgba(0,0,0,.95);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--space-sm);padding-top:calc(var(--space-md) + env(safe-area-inset-top, 0px));padding-bottom:calc(var(--space-md) + env(safe-area-inset-bottom, 0px))}.photo-viewer--fullscreen{padding:env(safe-area-inset-top,0) 0 env(safe-area-inset-bottom,0)}.photo-viewer__content{position:relative;max-width:100%;max-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);height:100%}.photo-viewer__image{max-width:100vw;max-height:calc(100vh - 72px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:var(--radius-sm);box-shadow:var(--shadow-medium)}.photo-viewer--fullscreen .photo-viewer__image{max-height:calc(100vh - 28px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));max-width:100vw}@media (max-width:520px){.photo-viewer{padding:env(safe-area-inset-top,0) 0 env(safe-area-inset-bottom,0)}.photo-viewer__image{max-width:100vw;max-height:calc(100vh - 64px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px));border-radius:0}}.photo-viewer__close{position:fixed;top:18px;right:18px;width:44px;height:44px;border-radius:50%;background:hsla(0,0%,100%,.14);border:1px solid hsla(0,0%,100%,.2);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-strong);transition:background .2s,transform .15s}.photo-viewer__top-actions{display:none}.photo-viewer__fs-icon{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom, 0px));width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.55);border:1px solid hsla(0,0%,100%,.2);color:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:var(--shadow-strong);transition:background .2s,transform .15s}.photo-viewer__fs-icon:hover{background:hsla(0,0%,100%,.2)}.photo-viewer__fs-icon:active{transform:scale(.96)}.rotate-hint{position:fixed;bottom:calc(18px + env(safe-area-inset-bottom, 0px));left:50%;transform:translateX(-50%);gap:var(--space-sm);padding:10px 14px;background:rgba(0,0,0,.7);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:12px;border:1px solid hsla(0,0%,100%,.12);box-shadow:var(--shadow-medium)}.rotate-hint,.rotate-hint__close{display:inline-flex;align-items:center;color:#fff}.rotate-hint__close{width:24px;height:24px;border-radius:50%;background:hsla(0,0%,100%,.14);justify-content:center}.photo-viewer__close:hover{background:hsla(0,0%,100%,.22)}.photo-viewer__close:active{transform:scale(.96)}.photo-viewer__nav{display:inline-flex;align-items:center;gap:var(--space-sm);padding:8px 12px;background:rgba(0,0,0,.35);border-radius:999px;border:1px solid hsla(0,0%,100%,.08)}.photo-viewer__nav-btn{width:38px;height:38px;border-radius:50%;background:hsla(0,0%,100%,.12);border:1px solid hsla(0,0%,100%,.16);color:#fff;font-size:18px;display:inline-flex;align-items:center;justify-content:center;transition:background .2s,transform .15s}.photo-viewer__nav-btn:hover{background:hsla(0,0%,100%,.2)}.photo-viewer__nav-btn:active{transform:scale(.95)}.photo-viewer__nav-btn:disabled{opacity:.45;cursor:default;transform:none}.photo-viewer__counter{font-family:var(--font-ui);font-size:12px;color:hsla(0,0%,100%,.85)}.photo-viewer__meta{text-align:center;max-width:min(760px,90vw);padding:10px 14px;background:linear-gradient(180deg,rgba(0,0,0,.5),rgba(0,0,0,.24));border-radius:var(--radius-md)}.photo-viewer__desc{font-family:var(--font-handwriting);font-size:22px;line-height:1.5;color:var(--text-primary)}.photo-viewer__date{margin-top:6px;font-family:var(--font-ui);font-size:12px;color:hsla(0,0%,100%,.7)}.photo-modal{text-align:center;position:relative;width:100%;height:100%}.photo-modal--fullscreen{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center}.photo-modal__image{width:100%;max-width:none;max-height:none;border-radius:var(--radius-lg)}.photo-modal__image--fullscreen{max-height:80vh;width:auto;max-width:90vw;-o-object-fit:contain;object-fit:contain;border-radius:0}.photo-modal__image--cover{width:100vw;height:100vh;max-width:none;max-height:none;-o-object-fit:cover;object-fit:cover}.photo-modal__image--contain{-o-object-fit:contain;object-fit:contain}.photo-modal__info{padding:var(--space-lg)}.photo-modal__info--overlay{position:absolute;bottom:18px;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:10px var(--space-md);background:linear-gradient(180deg,transparent,rgba(0,0,0,.55))}.photo-modal__date{font-family:var(--font-ui);font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-sm)}.photo-modal__desc{font-family:var(--font-handwriting);font-size:22px;color:var(--text-primary);line-height:1.5}.photo-modal__controls{display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.photo-modal__desc-overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--space-xl) var(--space-lg) var(--space-lg);background:linear-gradient(0deg,rgba(0,0,0,.7) 0,rgba(0,0,0,.4) 60%,transparent)}.photo-modal__desc-text{font-family:var(--font-ui);font-size:14px;color:hsla(0,0%,100%,.9);line-height:1.5;max-width:400px;margin:0 auto;text-align:center}.about-modal{padding:var(--space-lg);max-width:360px}.about-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.about-modal__title{font-size:15px;font-weight:700}.about-modal__text{font-family:var(--font-ui);font-size:14px;color:var(--text-primary);line-height:1.5}.about-modal__close{background:hsla(0,0%,100%,.08);border-radius:50%;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center}.comments-modal{width:100%;max-width:360px}.comments-modal__header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid hsla(0,0%,100%,.08);display:flex;justify-content:space-between;align-items:center}.comments-modal__title{font-family:var(--font-ui);font-size:16px;font-weight:600}.comments-modal__list{padding:var(--space-md);max-height:350px;overflow-y:auto}.comment{position:relative;background:var(--bg-paper-creamy);background-image:radial-gradient(circle at 20% 20%,rgba(0,0,0,.02) 0 2px,transparent 2px),radial-gradient(circle at 80% 50%,rgba(0,0,0,.02) 0 2px,transparent 2px),linear-gradient(180deg,hsla(0,0%,100%,.06),rgba(0,0,0,.02));background-size:140px 140px,180px 180px,auto;background-repeat:repeat;background-blend-mode:multiply;padding:calc(var(--space-md) - 2px) var(--space-lg);border-radius:var(--radius-bubble);border-bottom-left-radius:var(--space-xs);margin-bottom:var(--space-md);margin-left:var(--space-md);max-width:85%;box-shadow:var(--shadow-bubble)}.comment:after{content:"";position:absolute;bottom:0;left:-8px;width:12px;height:12px;background:var(--bg-paper-creamy);clip-path:polygon(100% 0,100% 100%,25% 100%,80% 0)}.comment__author{font-family:var(--font-ui);font-size:11px;font-weight:600;color:var(--accent-muted);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.5px}.comment__text{font-family:var(--font-handwriting);font-size:20px;line-height:var(--line-height-ruled);color:var(--text-ink)}.more-menu{position:absolute;right:0;top:28px;background:rgba(0,0,0,.7);border-radius:var(--radius-md);padding:6px 0;min-width:120px;box-shadow:var(--shadow-medium);z-index:20}.more-menu__item{width:100%;text-align:left;padding:8px 12px;background:transparent;color:var(--text-primary);font-family:var(--font-ui);font-size:13px}.more-menu__item:hover{background:hsla(0,0%,100%,.08)}.welcome-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px 20px;background:radial-gradient(circle at 20% 20%,hsla(0,0%,100%,.06),transparent 40%),radial-gradient(circle at 80% 0,hsla(0,0%,100%,.05),transparent 35%),linear-gradient(180deg,#0f0d0c,#1a1612 45%,#0f0d0c)}.welcome-card{width:100%;max-width:520px;background:var(--bg-paper-creamy);background-image:radial-gradient(circle at 20% 20%,rgba(0,0,0,.02) 0 2px,transparent 2px),radial-gradient(circle at 80% 50%,rgba(0,0,0,.02) 0 2px,transparent 2px),linear-gradient(180deg,hsla(0,0%,100%,.06),rgba(0,0,0,.02));background-size:140px 140px,180px 180px,auto;background-repeat:repeat;background-blend-mode:multiply;border-radius:20px;box-shadow:0 18px 50px rgba(0,0,0,.3);padding:26px 22px 20px;color:var(--text-dark)}.welcome-hero{display:flex;flex-direction:column;gap:10px;align-items:center;margin-bottom:16px}.welcome-hero--simple{align-items:flex-start}.welcome-logo-wrap{display:flex;justify-content:center;width:100%}.welcome-logo-bg{background:linear-gradient(135deg,#0f0d0c,#25201b);padding:14px 20px;border-radius:18px;box-shadow:var(--shadow-medium);display:inline-flex;align-items:center;justify-content:center}.welcome-logo{width:160px;height:auto;display:block}.welcome-tagline{font-size:20px;text-align:center}.welcome-doc-title,.welcome-tagline{font-family:var(--font-handwriting);color:var(--text-dark)}.welcome-doc-title{font-size:26px}.welcome-content{display:flex;flex-direction:column;gap:14px}.welcome-block{font-family:var(--font-handwriting);font-size:20px;line-height:var(--line-height-ruled);background:hsla(0,0%,100%,.8);border:1px solid rgba(0,0,0,.04);border-radius:16px;padding:16px;box-shadow:var(--shadow-soft)}.welcome-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}.welcome-button{padding:12px 16px;border-radius:14px;border:1px solid var(--text-dark);background:transparent;color:var(--text-dark);font-weight:600;font-size:15px;transition:transform .08s ease,box-shadow .12s ease,background-color .12s ease}.welcome-button:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft);background:rgba(0,0,0,.02)}.welcome-button:disabled{opacity:.6;cursor:not-allowed}.welcome-button--primary{background:#0f0d0c;color:#f7f3ec;border-color:#0f0d0c}.welcome-button--primary:hover{background:#1a1612}.welcome-button--ghost{border-style:dashed}.welcome-button--wide{width:100%;justify-content:center}.welcome-inline-message{margin-top:8px;font-family:var(--font-ui);font-size:13px;color:var(--accent)}.welcome-returning{margin-top:12px;padding-top:14px;border-top:1px dashed #d6ccc2;display:flex;flex-direction:column;gap:12px}.welcome-returning__form{display:flex;flex-direction:column;gap:10px}.welcome-input__label{font-size:12px}.welcome-input,.welcome-input__label{font-family:var(--font-ui);color:var(--text-dark)}.welcome-input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid #d6ccc2;background:#fdfaf5;font-size:14px}.welcome-input:focus{outline:2px solid #0f0d0c;outline-offset:1px}.welcome-status{font-family:var(--font-ui);font-size:13px;padding:10px 12px;border-radius:12px}.welcome-status--success{background:#ecfdf3;color:#166534;border:1px solid #bbf7d0}.welcome-status--error{background:#fef2f2;color:#7f1d1d;border:1px solid #fecaca}.welcome-footer{margin-top:20px;border-top:1px solid rgba(0,0,0,.06);padding-top:12px}.welcome-footer__links{display:flex;justify-content:center;align-items:center;gap:10px;font-family:var(--font-ui);font-size:13px}.welcome-footer__divider{width:6px;height:6px;border-radius:50%;background:#d6ccc2}.welcome-link{color:var(--text-dark);text-decoration:underline;text-decoration-thickness:1px}.welcome-loading{font-family:var(--font-ui);color:var(--text-dark);text-align:center}.documents-modal{width:100%;max-width:360px}.documents-modal__content{padding:16px;display:flex;flex-direction:column;gap:12px}.documents-link{display:block;width:100%;padding:12px 14px;border-radius:14px;border:1px solid #d6ccc2;background:var(--bg-paper-creamy);font-family:var(--font-handwriting);font-size:20px;color:var(--text-dark);text-align:center}.menu-btn{position:fixed;top:6px;right:6px;touch-action:manipulation;bottom:auto;left:auto;transform:none;background:rgba(0,0,0,.25);width:40px;height:40px;padding:0;justify-content:center;backdrop-filter:blur(6px);border-radius:50%;display:flex;align-items:center;gap:0;font-family:var(--font-ui);font-size:14px;font-weight:500;box-shadow:0 2px 8px rgba(0,0,0,.3);z-index:110;transition:transform .2s,background .2s;border:1px solid hsla(0,0%,100%,.1)}.menu-btn:hover{transform:scale(1.1);background:rgba(0,0,0,.35)}.menu-btn__icon{width:18px;height:18px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.bottom-sheet{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:var(--max-width);background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-lg);padding-bottom:calc(var(--space-xl) + env(safe-area-inset-bottom, 0px));z-index:200;box-shadow:var(--shadow-strong);max-height:80vh;overflow-y:auto}.bottom-sheet__close-btn{position:absolute;top:10px;right:12px;width:36px;height:36px;border-radius:50%;background:hsla(0,0%,100%,.08);color:var(--text-primary);display:inline-flex;align-items:center;justify-content:center;font-size:18px;border:1px solid hsla(0,0%,100%,.08)}.bottom-sheet__close-btn:hover{background:hsla(0,0%,100%,.14)}.bottom-sheet__handle{width:40px;height:4px;background:hsla(0,0%,100%,.2);border-radius:2px;margin:0 auto var(--space-lg)}.bottom-sheet__items{display:flex;flex-direction:column;gap:var(--space-xs)}.bottom-sheet__item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:15px;font-weight:500;transition:background .2s}.bottom-sheet__item:hover{background:hsla(0,0%,100%,.06)}.bottom-sheet__item--disabled{opacity:.6;cursor:default}.bottom-sheet__icon{width:44px;height:44px;background:hsla(0,0%,100%,.08);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px}.install-hint{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);width:calc(100% - 24px);max-width:var(--max-width);background:rgba(0,0,0,.78);color:#fff;border:1px solid hsla(0,0%,100%,.08);border-radius:14px;padding:12px 44px 12px 14px;font-family:var(--font-ui);font-size:14px;line-height:1.4;box-shadow:var(--shadow-strong);z-index:180}.install-hint__title{font-weight:600;margin-bottom:2px}.install-hint__text{color:var(--text-secondary)}.install-hint__close{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;background:hsla(0,0%,100%,.1);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:16px;line-height:1;transition:background .2s}.install-hint__close:hover{background:hsla(0,0%,100%,.2)}.install-banner{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);width:calc(100% - 24px);max-width:var(--max-width);background:rgba(0,0,0,.78);color:#fff;border:1px solid hsla(0,0%,100%,.08);border-radius:14px;padding:12px var(--space-md);font-family:var(--font-ui);font-size:14px;line-height:1.4;box-shadow:var(--shadow-strong);z-index:180;display:flex;align-items:center;gap:var(--space-md)}.install-banner__text{flex:1;color:hsla(0,0%,100%,.9)}.install-banner__actions{display:inline-flex;align-items:center;gap:var(--space-sm)}.install-banner__btn{padding:8px 12px;background:var(--accent);color:#fff;border-radius:var(--radius-md);font-family:var(--font-ui);font-size:13px;font-weight:600}.install-banner__btn:hover{background:var(--accent-hover)}.install-banner__close{width:28px;height:28px;border-radius:50%;background:hsla(0,0%,100%,.14);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:16px}.install-banner__close:hover{background:hsla(0,0%,100%,.22)}.install-modal{padding:var(--space-lg);max-width:420px}.install-modal__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.install-modal__title{font-size:16px;font-weight:700}.install-modal__close{background:hsla(0,0%,100%,.08);border-radius:50%;width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;font-size:18px}.install-modal__body{font-family:var(--font-ui);font-size:14px;color:var(--text-primary);line-height:1.5}.install-modal__steps{list-style:none;padding-left:0;display:grid;gap:8px}.install-modal__steps li{background:hsla(0,0%,100%,.04);padding:10px 12px;border-radius:var(--radius-md);border:1px solid hsla(0,0%,100%,.08)}.view-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border-bottom:1px solid hsla(0,0%,100%,.08)}.view-header__back{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;background:hsla(0,0%,100%,.08);transition:background .2s}.view-header__back:hover{background:hsla(0,0%,100%,.12)}.view-header__title{font-family:var(--font-ui);font-size:18px;font-weight:600}.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm);padding:var(--space-md)}.gallery-item{cursor:pointer;transition:transform .2s}.gallery-item:hover{transform:scale(.98)}.gallery-item__image{width:100%;aspect-ratio:1;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-md)}.gallery-item__date{font-family:var(--font-ui);font-size:11px;color:var(--text-secondary);margin-top:var(--space-xs);text-align:center}.gallery-item__count{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.55);color:#fff;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.gallery-item{position:relative}.gallery-tabs{display:flex;gap:var(--space-sm);padding:var(--space-md);padding-bottom:0}.gallery-tab{flex:1;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:hsla(0,0%,100%,.06);color:var(--text-secondary);font-family:var(--font-ui);font-size:13px;font-weight:600;text-align:center;transition:background .2s,color .2s}.gallery-tab--active{background:hsla(0,0%,100%,.12);color:var(--text-primary)}.audio-section{padding:var(--space-md)}.audio-section__title{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-md);text-transform:uppercase;letter-spacing:1.5px}.audio-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:hsla(0,0%,100%,.04);border-radius:var(--radius-md);margin-bottom:var(--space-sm);transition:background .2s}.audio-item:hover{background:hsla(0,0%,100%,.08)}.audio-item__play{width:44px;height:44px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:transform .2s,background .2s}.audio-item__play:hover{background:var(--accent-hover);transform:scale(1.05)}.audio-item__info{flex:1}.audio-item__title{font-family:var(--font-ui);font-size:14px;font-weight:500;margin-bottom:var(--space-xs)}.audio-item__duration{font-family:var(--font-ui);font-size:12px;color:var(--text-secondary)}.write-view{min-height:100vh;background:var(--bg-paper);display:flex;flex-direction:column}.write-view__paper{flex:1;padding:var(--space-lg);padding-top:calc(60px - 4px);background:var(--bg-paper);background-image:radial-gradient(circle at 20% 20%,rgba(0,0,0,.02) 0 2px,transparent 2px),radial-gradient(circle at 80% 50%,rgba(0,0,0,.02) 0 2px,transparent 2px),linear-gradient(180deg,hsla(0,0%,100%,.06),rgba(0,0,0,.02));background-size:140px 140px,180px 180px,auto;background-repeat:repeat;background-blend-mode:multiply}.write-view__textarea{width:100%;height:100%;min-height:400px;background:hsla(38,44%,96%,.96);border:1px solid rgba(0,0,0,.06);resize:none;font-family:var(--font-handwriting);font-size:24px;line-height:var(--line-height-ruled);color:var(--text-ink);padding-top:4px;border-radius:var(--radius-md)}.create-tabs{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-sm);margin-bottom:var(--space-md)}.create-tab{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);background:hsla(0,0%,100%,.06);color:var(--text-primary);font-family:var(--font-ui);font-size:13px;font-weight:600;transition:background .2s,transform .15s}.create-tab--active{background:hsla(0,0%,100%,.12);transform:translateY(-1px)}.create-section{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.create-label{font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--text-secondary);letter-spacing:.5px;text-transform:uppercase}.create-input{width:100%;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid rgba(0,0,0,.05);background:var(--bg-paper);color:var(--text-dark);font-family:var(--font-ui);font-size:14px}.create-input::-moz-placeholder{color:rgba(42,37,32,.55)}.create-input::placeholder{color:rgba(42,37,32,.55)}.create-card{padding:var(--space-md);background:hsla(0,0%,100%,.04);border-radius:var(--radius-lg);border:1px solid hsla(0,0%,100%,.08);box-shadow:var(--shadow-soft);color:var(--text-primary);font-family:var(--font-ui)}.create-file-name{font-size:13px;font-weight:600}.create-file-sizes{font-size:12px;color:var(--text-secondary);margin-bottom:var(--space-sm)}.create-previews-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:8px}.create-preview-img{width:100%;aspect-ratio:1;-o-object-fit:cover;object-fit:cover;border-radius:8px}.create-preview-wrapper{position:relative;border-radius:10px;overflow:hidden}.create-preview-remove{position:absolute;top:4px;right:4px;width:26px;height:26px;border-radius:50%;background:rgba(0,0,0,.45);color:#fff;font-size:16px;line-height:1}.create-preview-add,.create-preview-remove{display:flex;align-items:center;justify-content:center}.create-preview-add{aspect-ratio:1;border-radius:10px;border:2px dashed hsla(0,0%,100%,.25);background:hsla(0,0%,100%,.04);color:hsla(0,0%,100%,.5);transition:background .2s,border-color .2s}.create-preview-add:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.4)}.create-preview-add .icon{width:24px;height:24px}.create-modal{width:100%;max-width:400px}.create-note{margin-top:var(--space-xs);font-size:12px;color:var(--text-secondary)}.personal-banner{display:inline-flex;align-items:center;gap:var(--space-sm);padding:calc(var(--space-sm) + 2px) var(--space-md);margin:0 var(--space-sm) var(--space-md);background:repeating-linear-gradient(transparent,transparent calc(var(--line-height-ruled) - 1px),var(--bg-paper-lines) calc(var(--line-height-ruled) - 1px),var(--bg-paper-lines) var(--line-height-ruled)),var(--bg-paper-creamy);border-radius:var(--radius-bubble);border-bottom-left-radius:var(--space-xs);box-shadow:var(--shadow-bubble);font-family:var(--font-handwriting);font-size:18px;color:var(--text-ink)}.write-view__textarea:focus{outline:none}.write-view__textarea::-moz-placeholder{color:rgba(31,59,112,.45)}.write-view__textarea::placeholder{color:rgba(31,59,112,.45)}.write-view__footer{padding:var(--space-md);background:var(--bg-paper);border-top:1px solid var(--bg-paper-lines)}.write-view__send{width:100%;padding:var(--space-md);background:var(--accent);color:#fff;border-radius:var(--radius-md);font-family:var(--font-ui);font-size:15px;font-weight:600;transition:background .2s,transform .15s}.write-view__send:hover{background:var(--accent-hover)}.write-view__send:active{transform:scale(.98)}.write-view .view-header{background:var(--bg-paper);border-bottom-color:var(--bg-paper-lines)}.write-view .view-header__back,.write-view .view-header__title{color:var(--text-dark)}.write-view .view-header__back{background:rgba(0,0,0,.05)}.treat-cards{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.treat-card{background:hsla(0,0%,100%,.04);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;border:1px solid hsla(0,0%,100%,.06);transition:background .2s}.treat-card:hover{background:hsla(0,0%,100%,.06)}.treat-card__icon{font-size:40px;margin-bottom:var(--space-md)}.treat-card__title{font-family:var(--font-ui);font-size:18px;font-weight:600;margin-bottom:var(--space-sm)}.treat-card__desc{color:var(--text-secondary);margin-bottom:var(--space-lg);line-height:1.5}.treat-card__btn,.treat-card__desc{font-family:var(--font-ui);font-size:14px}.treat-card__btn{display:inline-block;padding:10px var(--space-lg);background:var(--accent);color:#fff;border-radius:var(--radius-md);font-weight:500;transition:background .2s,transform .15s}.treat-card__btn:hover{background:var(--accent-hover)}.treat-card__btn:active{transform:scale(.97)}.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:var(--bg-secondary);color:var(--text-primary);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-strong);font-family:var(--font-ui);font-size:14px;z-index:300;border:1px solid hsla(0,0%,100%,.1)}.backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);backdrop-filter:blur(2px);z-index:150}.home-view{position:relative;width:100%;max-width:var(--max-width);min-height:100vh;overflow-x:hidden}.home-view--hidden{opacity:0;pointer-events:none}.top-branding{position:fixed;top:0;left:0;right:0;z-index:50;padding:var(--space-lg) var(--space-lg) var(--space-xl);padding-top:calc(var(--space-lg) + env(safe-area-inset-top, 0px));background:linear-gradient(180deg,rgba(0,0,0,.6) 0,rgba(0,0,0,.4) 40%,rgba(0,0,0,.15) 70%,transparent);backdrop-filter:blur(2px);text-align:center;pointer-events:none}.top-branding__logo-line{position:relative;display:inline-block;line-height:1}.top-branding__prefix{position:absolute;left:6px;top:2px;font-family:var(--font-ui);font-size:12px;font-weight:500;color:hsla(0,0%,100%,.78);letter-spacing:2.2px;text-transform:uppercase;text-shadow:0 1px 4px rgba(0,0,0,.55)}.top-branding__name{font-family:Great Vibes,cursive;font-size:44px;font-weight:400;color:hsla(0,0%,100%,.98);letter-spacing:.2px;text-shadow:0 4px 14px rgba(0,0,0,.55);padding-top:10px;display:inline-block}.top-branding__tagline{font-family:var(--font-ui);font-size:13px;font-weight:600;color:hsla(0,0%,100%,.78);letter-spacing:.8px;margin-top:10px;text-shadow:0 2px 8px rgba(0,0,0,.45)}.fullscreen-bg{position:fixed;top:0;left:0;transform:none;width:100vw;max-width:none;height:100vh;z-index:0}.fullscreen-bg__image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center}.fullscreen-bg__overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,rgba(0,0,0,.5) 0,rgba(0,0,0,.25) 30%,rgba(0,0,0,.35) 70%,rgba(0,0,0,.75))}.photo-header{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:min(var(--max-width),100vw);padding:var(--space-lg) var(--space-md);padding-bottom:calc(56px + env(safe-area-inset-bottom, 0px));display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-md);z-index:10;background:linear-gradient(0deg,rgba(0,0,0,.55) 0,rgba(0,0,0,.3) 50%,transparent)}.photo-header__info{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);transform:translate(6px,36px)}.photo-header__label-row{display:flex;align-items:center;gap:var(--space-sm)}.photo-header__label{font-weight:600;color:hsla(0,0%,100%,.85);letter-spacing:.5px;text-transform:uppercase}.photo-header__date,.photo-header__label{font-family:var(--font-ui);font-size:12px}.photo-header__date{font-weight:500;color:hsla(0,0%,100%,.6)}.photo-header__nav{display:flex;gap:var(--space-sm);transform:translate(-6px,36px)}.photo-header__nav-btn{width:36px;height:36px;border-radius:50%;background:hsla(0,0%,100%,.12);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-primary);transition:background .2s,transform .15s;border:1px solid hsla(0,0%,100%,.1)}.photo-header__nav-btn:hover{background:hsla(0,0%,100%,.2)}.photo-header__nav-btn:active{transform:scale(.95)}.photo-header__nav-btn:disabled{opacity:.4;cursor:default}.photo-header__about-chip{display:flex;align-items:center;gap:6px;font-family:var(--font-ui);font-size:12px;font-weight:500;color:hsla(0,0%,100%,.85);padding:6px 12px;border-radius:var(--radius-sm);background:hsla(0,0%,100%,.12);backdrop-filter:blur(4px);transition:background .2s,transform .15s;border:1px solid hsla(0,0%,100%,.15)}.photo-header__about-chip:hover{background:hsla(0,0%,100%,.18)}.photo-header__about-chip:active{transform:scale(.96)}.photo-header__about{width:36px;height:36px;border-radius:50%;border:1px solid hsla(0,0%,100%,.35);background:rgba(0,0,0,.35);color:hsla(0,0%,100%,.95);display:inline-flex;align-items:center;justify-content:center;font-size:12px;text-transform:lowercase;letter-spacing:.3px}.feed--overlay{position:relative;z-index:5;padding-top:92px;min-height:100vh}.feed{padding:0 12px 96px 6px}@media (min-width:520px){.feed{padding-left:10px;padding-right:var(--space-md)}}.feed__title{font-family:var(--font-ui);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:hsla(0,0%,100%,.5)}.feed__intro,.feed__title{margin-bottom:var(--space-lg);margin-left:var(--space-sm)}.feed__intro{font-family:var(--font-handwriting);font-size:24px;color:hsla(0,0%,100%,.8)}.notification-banner{position:fixed;top:56px;left:var(--space-md);right:var(--space-md);z-index:90;display:flex;gap:var(--space-sm);padding:10px var(--space-md);margin:0;background:rgba(27,24,22,.95);border-radius:var(--radius-lg);border:none;border:1px solid hsla(0,0%,100%,.1);font-family:var(--font-ui);box-shadow:var(--shadow-medium);touch-action:manipulation}.badge,.notification-banner{align-items:center;justify-content:center;color:#fff}.badge{display:inline-flex;background:var(--accent);border-radius:999px;font-size:11px;font-weight:700}.badge--pill{min-width:18px;height:18px;padding:0 6px}.badge--alert{min-width:10px;height:10px}.empty-state{padding:var(--space-lg);text-align:center;color:var(--text-secondary);background:hsla(0,0%,100%,.04);border-radius:var(--radius-lg);border:1px solid hsla(0,0%,100%,.08)}.empty-state__title{font-size:15px;font-weight:700;color:var(--text-primary)}.empty-state__subtitle{margin-top:6px;font-size:13px}.swipe-container{touch-action:pan-y;-webkit-user-select:none;-moz-user-select:none;user-select:none}.swipe-dots{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom, 0px));left:50%;transform:translateX(-50%);display:flex;gap:var(--space-sm);z-index:10}.swipe-dot{width:6px;height:6px;border-radius:50%;background:hsla(0,0%,100%,.35);transition:background .3s,transform .3s}.swipe-dot--active{background:hsla(0,0%,100%,.9);transform:scale(1.4)}.swipe-dots__more{font-family:var(--font-ui);font-size:10px;color:hsla(0,0%,100%,.6);margin-left:var(--space-xs)}.icon{width:16px;height:16px;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;fill:none;flex-shrink:0}.icon--lg{width:20px;height:20px}.create-tabs--5{grid-template-columns:repeat(5,minmax(0,1fr))}@media (max-width:480px){.create-tabs--5{grid-template-columns:repeat(3,minmax(0,1fr))}.create-tabs--5 .create-tab:nth-child(4),.create-tabs--5 .create-tab:nth-child(5){grid-column:span 1}}.i18n-mode-selector{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.i18n-mode-btn{flex:1;padding:var(--space-md);border-radius:var(--radius-md);background:hsla(0,0%,100%,.06);border:2px solid transparent;color:var(--text-secondary);font-family:var(--font-ui);font-size:14px;font-weight:600;transition:all .2s}.i18n-mode-btn:hover{background:hsla(0,0%,100%,.1);color:var(--text-primary)}.i18n-mode-btn--active{background:hsla(0,0%,100%,.12);border-color:var(--accent);color:var(--text-primary)}.i18n-entries{display:flex;flex-direction:column;gap:var(--space-md)}.i18n-entry{background:hsla(0,0%,100%,.04);border-radius:var(--radius-lg);border:1px solid hsla(0,0%,100%,.08);padding:var(--space-md)}.i18n-entry__header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.i18n-entry__flag{font-size:20px}.i18n-entry__label{font-family:var(--font-ui);font-size:14px;font-weight:600;color:var(--text-primary);flex:1}.i18n-entry__code{font-family:var(--font-ui);font-size:11px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;background:hsla(0,0%,100%,.08);border-radius:var(--radius-sm)}.i18n-entry__textarea{width:100%;min-height:80px;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);border:1px solid rgba(0,0,0,.05);background:var(--bg-paper);color:var(--text-dark);font-family:var(--font-handwriting);font-size:18px;line-height:1.4;resize:none}.i18n-entry__textarea::-moz-placeholder{color:rgba(42,37,32,.45);font-family:var(--font-ui);font-size:14px}.i18n-entry__textarea::placeholder{color:rgba(42,37,32,.45);font-family:var(--font-ui);font-size:14px}.i18n-entry__upload{min-height:100px}.i18n-upload-btn{width:100%;min-height:100px;border:2px dashed hsla(0,0%,100%,.25);border-radius:var(--radius-md);background:hsla(0,0%,100%,.04);color:var(--text-secondary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);font-family:var(--font-ui);font-size:13px;transition:all .2s}.i18n-upload-btn:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.4);color:var(--text-primary)}.i18n-upload-btn .icon{width:24px;height:24px}.i18n-preview-wrapper{position:relative;border-radius:var(--radius-md);overflow:hidden}.i18n-preview-img{width:100%;max-height:200px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-md)}.i18n-preview-remove{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;background:rgba(0,0,0,.6);color:#fff;font-size:16px;display:flex;align-items:center;justify-content:center;transition:background .2s}.i18n-preview-remove:hover{background:rgba(0,0,0,.8)}.message--i18n{margin-bottom:200px;max-width:88%;margin-left:0}@media (min-width:520px){.message--i18n{max-width:82%;margin-left:2px}}.i18n-bubbles{gap:var(--space-md)}.i18n-bubble,.i18n-bubbles{display:flex;flex-direction:column}.i18n-bubble{gap:var(--space-xs)}.i18n-bubble__lang{display:flex;align-items:center;gap:6px;margin-left:var(--space-sm)}.i18n-bubble__flag{font-size:14px}.i18n-bubble__code{font-family:var(--font-ui);font-size:10px;font-weight:700;color:hsla(0,0%,100%,.7);text-transform:uppercase;letter-spacing:.5px;padding:2px 6px;background:hsla(0,0%,100%,.12);border-radius:var(--radius-sm)}.i18n-bubble__content{margin:0}.i18n-meta{font-family:var(--font-ui);font-size:11px;font-weight:600;color:hsla(0,0%,100%,.55);margin-top:var(--space-sm);margin-left:var(--space-sm)}.i18n-header{display:flex;justify-content:flex-start;gap:8px;width:100%;margin-left:0}.i18n-flags{display:inline-flex;gap:8px}.i18n-flag{width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.08);border:2px solid transparent;display:inline-flex;align-items:center;justify-content:center;font-size:16px;transition:background .2s,border-color .2s}.i18n-flag--active{background:hsla(0,0%,100%,.16);border-color:hsla(0,0%,100%,.4)}.i18n-missing{font-family:var(--font-ui);font-size:12px;color:rgba(43,65,106,.9);margin-bottom:8px}.i18n-missing--overlay{position:absolute;bottom:12px;left:12px;right:12px;padding:10px 12px;background:rgba(0,0,0,.65);border-radius:var(--radius-md);color:#fff;font-size:12px}.i18n-carousel{position:relative;max-width:200px;margin:0;align-self:flex-start}.i18n-carousel__image-container{position:relative;border-radius:var(--radius-lg);overflow:hidden;cursor:pointer}.i18n-carousel__image{width:100%;max-height:320px;height:auto;display:block;border-radius:var(--radius-lg);-o-object-fit:contain;object-fit:contain}.i18n-carousel__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-top:var(--space-xs)}.i18n-carousel__lang-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);border-radius:var(--radius-md);border:1px solid hsla(0,0%,100%,.15)}.i18n-carousel__flag{font-size:16px}.i18n-carousel__code{font-family:var(--font-ui);font-size:12px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}.i18n-carousel__controls{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-sm);margin-left:auto}.i18n-carousel__nav{display:inline-flex;align-items:center;gap:var(--space-xs)}.i18n-carousel__nav-btn{width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.55);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:18px;border:1px solid hsla(0,0%,100%,.2)}.i18n-carousel__counter{padding:6px 10px;border-radius:999px;background:rgba(0,0,0,.55);color:hsla(0,0%,100%,.9);font-family:var(--font-ui);font-size:12px;font-weight:700}.i18n-carousel__meta{font-family:var(--font-ui);font-size:11px;font-weight:600;color:hsla(0,0%,100%,.55);margin-top:var(--space-sm);text-align:center}.placeholder\:text-white\/40::-moz-placeholder{color:hsla(0,0%,100%,.4)}.placeholder\:text-white\/40::placeholder{color:hsla(0,0%,100%,.4)}.hover\:bg-white\/15:hover{background-color:hsla(0,0%,100%,.15)}.hover\:bg-white\/90:hover{background-color:hsla(0,0%,100%,.9)}.focus\:border-white\/25:focus{border-color:hsla(0,0%,100%,.25)}.disabled\:opacity-50:disabled{opacity:.5}