:root{--bg: #fbf7f4;--bg-grad-1: #f7e9f0;--bg-grad-2: #e8eef7;--bg-grad-3: #f3eef9;--surface: rgba(255, 255, 255, .66);--surface-solid: #fffdfb;--ink: #4a4458;--ink-soft: #8a8398;--ink-faint: #b6b0c2;--rose: #f4c7d4;--lilac: #d8cdf0;--sky: #c7dbf0;--mint: #c9e7d8;--peach: #f7d9c4;--accent: #c9a7e6;--accent-deep: #a07cc7;--line: rgba(120, 110, 140, .14);--shadow: 0 10px 40px rgba(150, 130, 170, .18);--radius: 22px;--radius-sm: 14px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Be Vietnam Pro,system-ui,sans-serif;color:var(--ink);background:radial-gradient(1100px 700px at 12% -8%,var(--bg-grad-1),transparent 60%),radial-gradient(1000px 800px at 100% 0%,var(--bg-grad-2),transparent 55%),radial-gradient(900px 900px at 50% 120%,var(--bg-grad-3),transparent 60%),var(--bg);background-attachment:fixed;-webkit-font-smoothing:antialiased}h1,h2,h3,.display{font-family:Quicksand,sans-serif;font-weight:600;letter-spacing:-.01em}a{color:var(--accent-deep);text-decoration:none}a:hover{text-decoration:underline}.app-shell{min-height:100%;display:flex;flex-direction:column}.nav{display:flex;align-items:center;justify-content:space-between;padding:20px 28px;gap:16px}.brand{font-family:Quicksand,sans-serif;font-weight:700;font-size:1.25rem;color:var(--ink);display:flex;align-items:center;gap:10px}.brand .dot{width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,var(--rose),var(--lilac));box-shadow:0 0 0 5px #d8cdf059}.nav-right{display:flex;align-items:center;gap:14px}.nav-user{color:var(--ink-soft);font-size:.9rem}.container{width:100%;max-width:1040px;margin:0 auto;padding:12px 24px 80px}.card{background:var(--surface);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.btn{font-family:Quicksand,sans-serif;font-weight:600;font-size:.95rem;border:none;cursor:pointer;padding:11px 20px;border-radius:999px;color:var(--ink);background:#ffffffb3;border:1px solid var(--line);transition:transform .15s ease,box-shadow .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 8px 22px #a08cbe38}.btn:active{transform:translateY(0)}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-deep));border:none}.btn-ghost{background:transparent;border:1px solid var(--line)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{padding:7px 14px;font-size:.85rem}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}.field label{font-size:.85rem;color:var(--ink-soft);font-weight:500}.input,.textarea{font-family:inherit;font-size:.98rem;color:var(--ink);background:var(--surface-solid);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px #c9a7e62e}.textarea{resize:vertical;min-height:90px;line-height:1.55}.auth-wrap{flex:1;display:grid;place-items:center;padding:40px 20px}.auth-card{width:100%;max-width:400px;padding:38px 34px}.auth-card h1{margin:0 0 4px;font-size:1.6rem}.auth-quote{font-style:italic;color:var(--ink-soft);font-size:.92rem;line-height:1.6;margin:0 0 26px}.auth-switch{text-align:center;margin-top:18px;color:var(--ink-soft);font-size:.9rem}.error-banner{background:#f4c7d466;border:1px solid rgba(220,150,170,.4);color:#9a5a6e;padding:10px 14px;border-radius:var(--radius-sm);font-size:.88rem;margin-bottom:16px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:18px 0 28px;flex-wrap:wrap}.page-head h1{margin:0;font-size:1.9rem}.page-head p{margin:6px 0 0;color:var(--ink-soft)}.roll-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:22px}.roll-tile{padding:0;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}.roll-tile:hover{transform:translateY(-3px);box-shadow:0 16px 44px #9682aa42}.roll-cover{aspect-ratio:4 / 3;background:linear-gradient(135deg,var(--rose),var(--sky));display:grid;place-items:center;position:relative}.roll-cover img{width:100%;height:100%;object-fit:cover}.roll-cover .placeholder{font-size:2.4rem;opacity:.6}.roll-tile .meta{padding:16px 18px 18px}.roll-tile .meta h3{margin:0 0 4px;font-size:1.08rem}.roll-tile .meta .sub{color:var(--ink-soft);font-size:.82rem}.pill{display:inline-block;padding:4px 11px;border-radius:999px;font-size:.74rem;font-weight:600;font-family:Quicksand,sans-serif}.pill-developed{background:#c9a7e638;color:var(--accent-deep)}.pill-open{background:#c9e7d880;color:#5a8a72}.counter{display:flex;align-items:center;gap:12px}.counter .big{font-family:Quicksand,sans-serif;font-weight:700;font-size:2rem;line-height:1}.counter .label{color:var(--ink-soft);font-size:.84rem}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-top:8px}.gallery-masonry{column-count:4;column-gap:16px;margin-top:8px}@media (max-width: 1000px){.gallery-masonry{column-count:3}}@media (max-width: 680px){.gallery-masonry{column-count:2}}.gallery-masonry .frame{aspect-ratio:auto;width:100%;display:inline-block;margin:0 0 16px;break-inside:avoid}.gallery-masonry .frame img,.gallery-masonry .frame video{height:auto;display:block}.gallery-masonry .frame .audio-body{min-height:150px}.gallery-masonry .frame .note-body{-webkit-line-clamp:12;min-height:120px}.gallery-reel-wrap{margin-top:8px}.gallery-reel{display:flex;gap:0;overflow-x:auto;scroll-snap-type:x mandatory;padding:30px 14px;border-radius:var(--radius);background-color:#2b2640;background-image:radial-gradient(circle,#fbf7f4 3px,transparent 3.6px),radial-gradient(circle,#fbf7f4 3px,transparent 3.6px);background-size:28px 14px,28px 14px;background-position:14px 9px,14px calc(100% - 9px);background-repeat:repeat-x,repeat-x}.gallery-reel .frame{flex:0 0 auto;width:220px;height:250px;aspect-ratio:auto;margin:0 12px;scroll-snap-align:center;border:none;border-radius:6px;box-shadow:0 6px 20px #0000004d}.gallery-reel .frame:hover{transform:translateY(-3px)}.gallery-reel .frame .num{background:#2b2640b3;color:#fff}.gallery-reel .frame .note-body{height:100%}.gallery-reel .frame-add{flex:0 0 auto;width:220px;height:250px;aspect-ratio:auto;margin:0 12px;background:#ffffff1f;border-color:#ffffff73;color:#f3eef9}.gallery-masonry .frame-add{aspect-ratio:1;margin-bottom:16px}.seg{display:inline-flex;background:#fff9;border:1px solid var(--line);border-radius:999px;padding:4px;gap:2px}.seg button{border:none;background:transparent;cursor:pointer;padding:7px 14px;border-radius:999px;font-family:Quicksand,sans-serif;font-weight:600;font-size:.82rem;color:var(--ink-soft);transition:all .15s ease}.seg button.active{background:#fff;color:var(--accent-deep);box-shadow:0 2px 8px #9682aa2e}.seg button:disabled{opacity:.5;cursor:not-allowed}.strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px;margin-top:8px}.frame{position:relative;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface-solid);border:1px solid var(--line);display:flex;flex-direction:column;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.frame:hover{transform:translateY(-2px) rotate(-.4deg);box-shadow:0 12px 30px #9682aa3d}.frame .num{position:absolute;top:8px;left:8px;z-index:2;font-family:Quicksand,sans-serif;font-weight:700;font-size:.72rem;background:#ffffffc7;color:var(--ink-soft);padding:2px 8px;border-radius:999px}.frame img,.frame video{width:100%;height:100%;object-fit:cover}.frame .note-body{padding:26px 14px 14px;font-size:.86rem;line-height:1.55;color:var(--ink);overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical;background:linear-gradient(160deg,#f7e9f099,#e8eef780)}.frame .audio-body{display:grid;place-items:center;height:100%;font-size:2rem;background:linear-gradient(135deg,var(--mint),var(--sky))}.frame .cap{position:absolute;bottom:0;left:0;right:0;padding:18px 10px 8px;font-size:.74rem;color:#fff;background:linear-gradient(transparent,#463c5aa8);overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.frame-add{display:grid;place-items:center;cursor:pointer;gap:6px;border:1.5px dashed var(--ink-faint);color:var(--ink-soft);background:#fff6;aspect-ratio:1;border-radius:var(--radius-sm);font-family:Quicksand,sans-serif;font-weight:600;transition:all .15s ease}.frame-add:hover{border-color:var(--accent);color:var(--accent-deep);background:#c9a7e61a}.frame-add .plus{font-size:1.8rem}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#4a445847;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:20px}.modal{width:100%;max-width:460px;padding:28px;background:var(--surface-solid)}.modal h2{margin:0 0 6px;font-size:1.3rem}.modal .hint{color:var(--ink-soft);font-size:.86rem;margin:0 0 20px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.kind-tabs{display:flex;gap:8px;margin-bottom:18px}.kind-tab{flex:1;padding:12px 8px;border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--line);background:var(--surface);text-align:center;font-size:.84rem;font-weight:500;color:var(--ink-soft);transition:all .15s ease}.kind-tab .ico{font-size:1.3rem;display:block;margin-bottom:4px}.kind-tab.active{border-color:var(--accent);background:#c9a7e624;color:var(--accent-deep)}.dropzone{border:1.5px dashed var(--ink-faint);border-radius:var(--radius-sm);padding:26px;text-align:center;color:var(--ink-soft);cursor:pointer;transition:all .15s ease;font-size:.9rem}.dropzone:hover{border-color:var(--accent);color:var(--accent-deep)}.preview-media{max-width:100%;max-height:220px;border-radius:var(--radius-sm);margin-top:6px}.empty{text-align:center;padding:70px 20px;color:var(--ink-soft)}.empty .big-emoji{font-size:3rem;margin-bottom:12px}.lightbox-media{max-width:100%;max-height:60vh;border-radius:var(--radius-sm);display:block;margin:0 auto}.lightbox-note{font-size:1.05rem;line-height:1.7;white-space:pre-wrap}.intro{flex:1}.intro-nav{display:flex;align-items:center;justify-content:space-between;padding:22px 32px;max-width:1100px;margin:0 auto}.hero{max-width:760px;margin:0 auto;padding:60px 24px 40px;text-align:center}.hero-tag{display:inline-block;font-family:Quicksand,sans-serif;font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:.72rem;color:var(--accent-deep);background:#c9a7e629;padding:6px 16px;border-radius:999px;margin-bottom:26px}.hero-title{font-size:clamp(2.2rem,6vw,3.6rem);line-height:1.08;margin:0 0 26px;background:linear-gradient(135deg,#6b5b8e,var(--accent-deep));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero-quote{font-style:italic;color:var(--ink);font-size:1.05rem;line-height:1.75;max-width:620px;margin:0 auto 18px;padding:18px 24px;border-left:3px solid var(--rose);background:#ffffff73;border-radius:0 var(--radius-sm) var(--radius-sm) 0;text-align:left}.hero-sub{color:var(--ink-soft);font-size:1rem;line-height:1.7;margin:0 auto 32px;max-width:560px}.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.features{max-width:920px;margin:30px auto;padding:0 24px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.feature{padding:26px 24px;text-align:center}.feature-ico{font-size:2.2rem;margin-bottom:12px}.feature h3{margin:0 0 8px;font-size:1.1rem}.feature p{margin:0;color:var(--ink-soft);font-size:.9rem;line-height:1.6}.closing{text-align:center;padding:50px 24px 30px}.closing p{font-family:Quicksand,sans-serif;font-weight:600;font-size:1.3rem;color:var(--ink);margin:0 0 22px}.intro-foot{text-align:center;padding:30px 24px 50px;font-size:.82rem}.center{display:grid;place-items:center;min-height:50vh;color:var(--ink-soft)}.muted{color:var(--ink-soft)}.row{display:flex;gap:10px;align-items:center}.spacer{flex:1}
