:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.clip-card{aspect-ratio:1;cursor:pointer;background-color:#e8e0d0;border-radius:4px;position:relative;overflow:hidden}.clip-card.empty{cursor:pointer;background-color:#0000;border:1.5px dashed #c8c4b4;justify-content:center;align-items:center;transition:border-color .15s,background-color .15s;display:flex}.clip-card.empty:hover{background-color:#2c5f2e0a;border-color:#2c5f2e}.empty-plus{color:#c8c4b4;-webkit-user-select:none;user-select:none;font-size:1.4rem;line-height:1;transition:color .15s}.clip-card.empty:hover .empty-plus{color:#2c5f2e}.clip-image{object-fit:cover;width:100%;height:100%;transition:transform .2s;display:block}.clip-card:hover .clip-image{transform:scale(1.04)}.clip-tags{opacity:0;background:linear-gradient(#0000,#00000080);flex-wrap:wrap;gap:3px;padding:5px;transition:opacity .2s;display:flex;position:absolute;bottom:0;left:0;right:0}.clip-card:hover .clip-tags{opacity:1}.clip-tag{color:#fff;background-color:#0006;border-radius:10px;padding:1px 5px;font-size:.6rem}.clip-like-btn{cursor:pointer;color:#aaa;background:#ffffffe0;border:none;border-radius:10px;padding:2px 6px;font-size:.7rem;line-height:1.4;transition:background-color .1s,color .1s;position:absolute;top:5px;right:5px}.clip-like-btn.liked{color:#e74c3c}.clip-like-btn:hover{background:#fff}.page{background-color:#f5f2e8;background-image:repeating-linear-gradient(0deg,#0000,#0000 27px,#0000000b 27px 28px),repeating-linear-gradient(90deg,#0000,#0000 27px,#00000006 27px 28px);flex-direction:column;flex-shrink:0;width:300px;height:480px;display:flex}.page-left{border-radius:8px 0 0 8px}.page-right{border-radius:0 8px 8px 0}.page-grid{flex:1;grid-template-rows:repeat(4,1fr);grid-template-columns:repeat(3,1fr);gap:8px;padding:12px;display:grid}.page-number{text-align:center;color:#aaa;padding:4px 8px 8px;font-size:.7rem}.book-container{flex-direction:column;align-items:center;gap:16px;padding:24px;display:flex}.notebook-spread{filter:drop-shadow(0 6px 24px #0000002e);align-items:stretch;display:flex}.notebook-spread:not(.notebook-spread--mobile){background-image:url(https://scrappa-images.s3.ap-northeast-1.amazonaws.com/images/ringnotebook.png);background-position:50%;background-repeat:no-repeat;background-size:130% 130%;border-radius:4px 8px 8px 4px}.notebook-spread:not(.notebook-spread--mobile) .page{background:0 0}.notebook-spread:not(.notebook-spread--mobile) .page-grid{gap:10px;padding:16px}.notebook-spread:not(.notebook-spread--mobile) .ring-binding{background:0 0}.notebook-spread:not(.notebook-spread--mobile) .coil{display:none}.coil{background:linear-gradient(#f2f1ef 0%,#d4d2d0 20%,#9a9896 45%,#b8b6b4 70%,#dcdad8 90%,#eeedeb 100%);border:1.5px solid #7a7876;border-radius:50%;width:28px;height:9px;position:relative;overflow:hidden;box-shadow:0 2px 4px #00000073,0 1px 1px #0003,inset 0 1px 2px #ffffff8c}.coil:before{content:"";filter:blur(1px);background:#fff9;border-radius:50%;width:28%;height:42%;position:absolute;top:8%;left:18%}.coil:after{content:"";filter:blur(1px);background:#ffffff40;border-radius:50%;width:12%;height:50%;position:absolute;top:20%;right:10%}.spread-navigation{align-items:center;gap:16px;display:flex}.nav-btn{cursor:pointer;color:#333;background:0 0;border:none;padding:4px 8px;font-size:1rem;transition:color .15s}.nav-btn:hover:not(:disabled){color:#000}.nav-btn:disabled{cursor:default}.nav-cover-btn{cursor:pointer;color:#666;background:0 0;border:1px solid #bbb;border-radius:6px;margin-right:8px;padding:3px 10px;font-size:.8rem;transition:background-color .15s,color .15s}.nav-cover-btn:hover{color:#333;background:#0000000f}.nav-indicator{color:#888;text-align:center;min-width:40px;font-size:.8rem}@media (width<=767px){.book-container{padding:16px 0}.notebook-spread--mobile{-webkit-user-select:none;user-select:none;-webkit-user-drag:none;filter:drop-shadow(0 4px 16px #00000026);border-radius:4px 8px 8px 4px;justify-content:center}.notebook-spread--mobile .ring-binding{display:none}.notebook-spread--mobile .page{background:0 0;width:min(400px,100vw - 8px);height:min(560px,140vw - 11.2px)}.notebook-spread--mobile-right .page-grid{gap:8px;padding:80px 80px 80px 50px}.notebook-spread--mobile-left .page-grid{gap:8px;padding:90px 50px 80px 80px}}.lp{color:#4a3728;background-color:#f5f0e8;min-height:100vh;font-family:Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif}.lp-hero{background-color:#f5f0e8;justify-content:center;align-items:center;padding:64px 48px;display:flex}.lp-notebook-cover{background-image:url(https://scrappa-images.s3.ap-northeast-1.amazonaws.com/images/ringnotebook-title.png);background-position:50%;background-repeat:no-repeat;background-size:cover;width:420px;min-height:520px;display:flex;position:relative}.lp-notebook-cover .ring-binding,.lp-notebook-cover .coil{display:none}.lp-cover-content{flex-direction:column;justify-content:center;align-items:center;gap:20px;padding:48px 36px;display:flex;position:absolute;inset:0 0 0 40px}.lp-logo{width:auto;height:130px}.lp-catchcopy{color:#4a3728;text-align:center;letter-spacing:.03em;white-space:nowrap;text-underline-offset:2px;margin:0;font-size:.91rem;font-weight:700;line-height:1.5;-webkit-text-decoration:underline #b6a9a066;text-decoration:underline #b6a9a066}.lp-desc{color:#6b5344;text-align:center;text-wrap:balance;margin:0;font-size:.6rem;line-height:1.8}.lp-google-btn{color:#333;cursor:pointer;background:#fff;border:none;border-radius:8px;align-items:center;gap:10px;width:fit-content;padding:12px 24px;font-size:.95rem;font-weight:500;transition:box-shadow .2s,transform .1s;display:inline-flex;box-shadow:0 2px 8px #0003}.lp-google-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.lp-google-btn:active{transform:translateY(0)}.lp-section{padding:72px 48px}.lp-section:nth-child(2n){background-color:#ede8d8}.lp-section-title{text-align:center;color:#4a3728;border-bottom:1px solid #0000001f;width:fit-content;margin:0 auto 12px;padding-bottom:4px;font-size:1.4rem;font-weight:700}.lp-section-sub{text-align:center;color:#6b5344;margin:0 0 40px;padding-bottom:16px;font-size:.95rem;line-height:1.55}.lp-concept-grid{justify-content:center;align-items:center;gap:24px;max-width:700px;margin:0 auto;display:flex}.lp-concept-card{text-align:center;background:#fff;border-radius:12px;flex:1;padding:24px;box-shadow:0 2px 12px #4a372814}.lp-concept-card ul{text-align:left;margin:12px 0 0;padding:0;list-style:none;display:inline-block}.lp-concept-card li{color:#4a3728;align-items:baseline;gap:2px;padding:5px 0;font-size:.92rem;line-height:1.5;display:flex}.lp-concept-card li:before{content:"・";color:#2c5f2e;flex-shrink:0}.lp-concept-label{box-sizing:border-box;text-align:center;border-radius:20px;width:100%;margin-bottom:4px;padding:3px 10px;font-size:.78rem;font-weight:700;display:inline-block}.lp-concept-label.analog{color:#fff;background:#c8a882}.lp-concept-label.digital{color:#fff;background:#2c5f2e}.lp-concept-plus{color:#585857;flex-shrink:0;font-size:5rem;font-weight:600}.lp-features-grid{grid-template-columns:repeat(2,1fr);gap:20px;max-width:800px;margin:40px auto 0;display:grid}.lp-feature-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 12px #4a372814}.lp-feature-num{color:#c8a882;margin-bottom:8px;font-size:1.6rem;font-weight:800;line-height:1}.lp-feature-title{color:#4a3728;margin:0 0 10px;font-size:1rem;font-weight:700}.lp-feature-body{color:#6b5344;margin:0;font-size:.88rem;line-height:1.7}.lp-howto{background-color:#ede8d8}.lp-steps{flex-direction:column;align-items:center;gap:0;max-width:560px;margin:40px auto 0;display:flex}.lp-step{background:#fff;border-radius:12px;align-items:flex-start;gap:20px;width:100%;padding:20px 24px;display:flex;box-shadow:0 2px 12px #4a372814}.lp-step-num{color:#fff;background:#2c5f2e;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;font-weight:700;display:flex}.lp-step-body{text-align:center;flex:1}.lp-step-body h3{color:#4a3728;margin:0 0 6px;font-size:.95rem;font-weight:700}.lp-step-body p{color:#6b5344;margin:0;font-size:.88rem;line-height:1.6}.lp-step-arrow{color:#c8a882;padding:6px 0;font-size:1.2rem}.lp-cta{text-align:center;flex-direction:column;align-items:center;gap:28px;padding:80px 48px;display:flex}.lp-cta-copy{color:#4a3728;margin:0;font-size:1.3rem;font-weight:700}.lp-footer{color:#4a372899;text-align:center;background:#f5f0e8;border-top:1px solid #00000014;padding:24px 16px;font-size:.8rem}.lp-footer-links{justify-content:center;gap:24px;margin-bottom:12px;display:flex}.lp-footer-links a{color:#4a3728b3;text-decoration:none;transition:color .15s}.lp-footer-links a:hover{color:#4a3728;text-decoration:underline}.lp-footer-copy{margin:0}@media (width<=767px){.lp-hero{padding:40px 20px}.lp-notebook-cover{width:min(420px,100vw - 32px);min-height:460px}.lp-section{padding:48px 20px}.lp-section-title{white-space:nowrap;font-size:1.1rem}.lp-concept-grid{flex-direction:column;gap:12px}.lp-concept-plus{padding:0;font-size:1.4rem}.lp-features-grid{grid-template-columns:1fr}.lp-cta{padding:56px 20px}}.loading-screen{flex-direction:column;justify-content:center;align-items:center;gap:16px;width:100%;padding-top:70px;padding-right:60px;display:flex}.loading-book{filter:drop-shadow(0 6px 24px #0000002e);align-items:stretch;gap:0;height:400px;margin:0 auto;display:flex}.loading-ring{flex-shrink:0;width:auto;height:100%;margin-right:-50px;display:block}.loading-pages{perspective:600px;width:250px;position:relative}.loading-page{transform-origin:0;background-color:#f5f2e8;background-image:repeating-linear-gradient(0deg,#0000,#0000 27px,#0000000b 27px 28px),repeating-linear-gradient(90deg,#0000,#0000 27px,#00000006 27px 28px);border:1px solid #0000000f;border-radius:0 4px 4px 0;animation:2.2s ease-in-out infinite page-flip;position:absolute;inset:0}@keyframes page-flip{0%{opacity:1;transform:rotateY(0)}45%{opacity:.6;transform:rotateY(-90deg)}90%{opacity:.1;transform:rotateY(-170deg)}to{opacity:0;transform:rotateY(-180deg)}}.page-1{animation-delay:0s}.page-2{animation-delay:.4s}.page-3{animation-delay:.8s}.page-4{animation-delay:1.2s}.loading-text{color:#6b5344;letter-spacing:.1em;margin:0;font-size:.9rem}.loading-text span{animation:.9s ease-in-out infinite text-wave;display:inline-block}@keyframes text-wave{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.cover-container{flex-direction:column;align-items:center;gap:20px;padding:32px 16px;display:flex}.cover-spread{filter:drop-shadow(0 4px 16px #0003);background-image:url(https://scrappa-images.s3.ap-northeast-1.amazonaws.com/images/ringnotebook-title.png);background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:4px 8px 8px 4px;width:420px;height:480px;position:relative}.cover-spread .ring-binding,.cover-spread .coil{display:none}.cover-page{box-sizing:border-box;border-radius:0 8px 8px 0;flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex;position:absolute;inset:0 0 0 25px;background:0 0!important}.cover-title{color:#333;text-align:center;word-break:break-all;cursor:pointer;margin:0 0 24px;font-size:1.2rem;font-weight:700;line-height:1.6}.cover-title-input{color:#4a3728;text-align:center;box-sizing:border-box;background:#ffffff80;border:2px solid #4a372866;border-radius:6px;outline:none;width:100%;margin:0 0 24px;padding:6px 8px;font-size:1.1rem;font-weight:700}.cover-open-btn{color:#080703;cursor:pointer;background:#f0eeeebf;border:1.5px solid #05050566;border-radius:6px;padding:8px 28px;font-size:.9rem;font-weight:600;transition:background-color .15s;display:block}.cover-open-btn:hover{background:#cfcfcfd9}.cover-actions{flex-direction:column;align-items:center;gap:8px;display:flex}.font-tabs{border-bottom:1px solid #d0c9be;justify-content:center;width:100%;display:flex}.font-tab{color:#888;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:6px 16px;font-size:.85rem;transition:color .15s,border-color .15s}.font-tab:hover{color:#4a3728}.font-tab.active{color:#4a3728;border-bottom-color:#4a3728;font-weight:600}.font-picker{flex-wrap:wrap;justify-content:center;gap:6px;min-height:36px;display:flex}.font-option{color:#555;cursor:pointer;background:0 0;border:1px solid #bbb;border-radius:6px;padding:5px 12px;font-size:.85rem;transition:background-color .15s,border-color .15s}.font-option:hover{background:#0000000f}.font-option.selected{color:#4a3728;background:#4a37280f;border-color:#4a3728;font-weight:600}@media (width<=767px){.cover-spread{aspect-ratio:420/480;width:min(420px,100vw - 32px);height:auto}}.tag-filter{scrollbar-width:none;-ms-overflow-style:none;gap:8px;padding:12px 16px;display:flex;overflow-x:auto}.tag-filter::-webkit-scrollbar{display:none}.tag-btn{color:#555;white-space:nowrap;cursor:pointer;background-color:#fff;border:1px solid #c8bfaa;border-radius:20px;align-items:center;gap:6px;padding:6px 16px;font-size:.85rem;transition:background-color .15s,color .15s;display:flex}.tag-btn.active{color:#fff;background-color:#4a7ab0;border-color:#4a7ab0}.tag-count{opacity:.7;font-size:.75rem}.tag-btn-wrapper{flex-shrink:0;align-items:center;display:flex;position:relative}.tag-edit-icon{cursor:pointer;color:#777;background:0 0;border:1px solid #c8bfaa;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:.65rem;line-height:1;transition:background-color .15s,border-color .15s;display:none}.tag-btn-wrapper:hover .tag-edit-icon{display:flex}.tag-edit-icon:hover{background-color:#f0ebe0;border-color:#aaa}.tag-edit-row{flex-shrink:0;align-items:center;gap:4px;display:flex}.tag-edit-input{color:#333;background-color:#fff;border:1px solid #4a7ab0;border-radius:20px;outline:none;width:120px;padding:5px 12px;font-size:.85rem}.tag-edit-delete{color:#c0392b;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1rem;line-height:1}@media (width<=767px){.tag-filter{padding:6px 12px}}.drop-zone{text-align:center;cursor:pointer;background-color:#faf7f2;border:2px dashed #c8bfaa;border-radius:8px;padding:48px 24px;transition:border-color .2s,background-color .2s}.drop-zone:hover,.drop-zone.dragging{background-color:#f0f5f0;border-color:#2c5f2e}.drop-zone-text{color:#555;margin:0 0 8px;font-size:1rem}.drop-zone-hint{color:#aaa;margin:0;font-size:.8rem}.preview-area{flex-direction:column;align-items:center;gap:12px;display:flex}.preview-image{object-fit:contain;background-color:#f0ebe0;border-radius:8px;width:100%;max-height:240px}.change-file-btn{color:#2c5f2e;cursor:pointer;background:0 0;border:1px solid #2c5f2e;border-radius:6px;padding:6px 16px;font-size:.85rem}.upload-error{color:#c0392b;flex:1;margin:0;font-size:.8rem}.crop-container{background:#000;border-radius:8px;width:100%;height:300px;position:relative;overflow:hidden}.crop-controls{flex-direction:column;align-items:center;gap:10px;padding-top:12px;display:flex}.crop-control-row{align-items:center;gap:8px;width:100%;display:flex}.crop-control-label{color:#888;white-space:nowrap;min-width:28px;font-size:.75rem}.crop-control-value{color:#888;text-align:right;min-width:32px;font-size:.75rem}.zoom-slider{accent-color:#2c5f2e;cursor:pointer;width:100%}.crop-confirm-btn{color:#fff;cursor:pointer;background-color:#2c5f2e;border:none;border-radius:6px;padding:8px 32px;font-size:.9rem;font-weight:600}.crop-confirm-btn:hover{background-color:#24512a}.memo-area{flex-direction:column;gap:6px;margin-top:4px;display:flex}.modal-overlay{z-index:1000;background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:#fff;border-radius:12px;flex-direction:column;width:480px;max-width:90vw;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 16px 48px #0003}.modal-header{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-title{color:#333;margin:0;font-size:1.1rem;font-weight:600}.modal-close{color:#888;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:1.4rem;line-height:1;transition:background-color .15s}.modal-close:hover{background-color:#f0f0f0}.modal-body{flex-direction:column;flex:1;gap:16px;padding:20px;display:flex;overflow-y:auto}.detail-image{object-fit:contain;background-color:#f0ebe0;border-radius:8px;width:100%;max-height:260px}.tag-input-area{flex-direction:column;gap:8px;display:flex}.tag-label{color:#555;font-size:.85rem;font-weight:600}.tag-chips{cursor:text;border:1px solid #ddd;border-radius:6px;flex-wrap:wrap;align-items:center;gap:6px;min-height:44px;padding:8px;display:flex}.tag-chip{color:#fff;background-color:#4a7ab0;border-radius:12px;align-items:center;gap:4px;padding:2px 10px;font-size:.8rem;display:flex}.tag-chip-remove{color:#fffc;cursor:pointer;background:0 0;border:none;padding:0;font-size:.9rem;line-height:1}.tag-input{color:#333;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:0 0;border:none;outline:none;flex:1;min-width:140px;font-size:.85rem}.modal-footer{border-top:1px solid #eee;justify-content:flex-end;gap:8px;padding:16px 20px;display:flex}.detail-footer{justify-content:space-between}.detail-footer-right{align-items:center;gap:8px;display:flex}.upload-error{color:#c0392b;margin:0;font-size:.8rem}.cancel-btn{color:#555;cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:6px;padding:8px 20px}.submit-btn{color:#fff;cursor:pointer;background-color:#2c5f2e;border:none;border-radius:6px;padding:8px 20px;font-weight:600}.submit-btn:disabled{cursor:not-allowed;background-color:#aaa}.detail-image-wrap{position:relative}.detail-like-btn{cursor:pointer;color:#888;background:#ffffffe0;border:none;border-radius:12px;align-items:center;gap:4px;padding:4px 10px;font-size:.82rem;line-height:1.4;transition:background-color .1s;display:flex;position:absolute;bottom:8px;right:8px}.detail-like-btn:hover{background:#fff}.detail-like-heart{color:#bbb;font-size:.95rem;transition:color .15s}.detail-like-btn.liked .detail-like-heart{color:#e74c3c}.clip-likes-count{color:#e74c3c;text-align:right;margin:-8px 0 0;font-size:.85rem}.memo-area{flex-direction:column;gap:6px;display:flex}.memo-label{color:#555;font-size:.85rem;font-weight:600}.memo-input{color:#666;resize:vertical;box-sizing:border-box;background:#fafaf8;border:1px solid #ddd;border-radius:6px;width:100%;padding:8px;font-family:inherit;font-size:.82rem;line-height:1.5}.memo-input:focus{border-color:#aaa;outline:none}.clip-memo-readonly{color:#aaa;white-space:pre-wrap;word-break:break-word;text-align:center;margin:0;font-size:.82rem;line-height:1.5}.delete-btn{color:#c0392b;cursor:pointer;background:0 0;border:1px solid #c0392b;border-radius:6px;padding:8px 20px;transition:background-color .15s}.delete-btn:hover{background-color:#fdf0ee}.delete-btn:disabled{color:#aaa;cursor:not-allowed;border-color:#aaa}.visibility-area{align-items:center;gap:12px;margin-top:4px;display:flex}.visibility-label{color:#555;font-size:.85rem;font-weight:600}.toggle-label{cursor:pointer;align-items:center;gap:8px;display:flex}.toggle-input{display:none}.toggle-slider{background:#ccc;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;display:inline-block;position:relative}.toggle-slider:before{content:"";background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:3px;left:3px}.toggle-input:checked+.toggle-slider{background:#2c5f2e}.toggle-input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-text{color:#555;font-size:.85rem}.profile-modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.profile-modal{background:#fff;border-radius:12px;flex-direction:column;align-items:center;gap:20px;width:340px;padding:28px 32px;display:flex;box-shadow:0 8px 32px #0000002e}.profile-modal-title{color:#222;align-self:flex-start;margin:0;font-size:1.1rem;font-weight:700}.avatar-upload-label{cursor:pointer;background:#e8e4d8;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:88px;height:88px;display:flex;position:relative;overflow:hidden}.avatar-preview{object-fit:cover;width:100%;height:100%}.avatar-placeholder{color:#888;font-size:2rem;font-weight:700}.avatar-upload-hint{color:#fff;opacity:0;background:#0006;border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;transition:opacity .15s;display:flex;position:absolute;inset:0}.avatar-upload-label:hover .avatar-upload-hint{opacity:1}.profile-field{flex-direction:column;gap:6px;width:100%;display:flex}.profile-label{color:#666;font-size:.82rem;font-weight:500}.profile-input{color:#222;box-sizing:border-box;background:#fff;border:1px solid #d0cbbf;border-radius:6px;outline:none;width:100%;padding:8px 12px;font-size:.95rem;transition:border-color .15s}.profile-input:focus{border-color:#2c5f2e}.profile-modal-actions{justify-content:flex-end;gap:10px;width:100%;display:flex}.profile-btn-cancel{color:#555;cursor:pointer;background:#fff;border:1px solid #d0cbbf;border-radius:6px;padding:8px 16px;font-size:.88rem;transition:background-color .1s}.profile-btn-cancel:hover{background-color:#f5f0e8}.profile-btn-save{color:#fff;cursor:pointer;background:#2c5f2e;border:none;border-radius:6px;padding:8px 20px;font-size:.88rem;transition:background-color .1s}.profile-btn-save:hover:not(:disabled){background-color:#245024}.profile-btn-save:disabled{opacity:.6;cursor:not-allowed}.user-menu{position:relative}.user-avatar-btn{cursor:pointer;background:#0000000d;border:2px solid #0003;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;transition:border-color .15s;display:flex;overflow:hidden}.user-avatar-btn:hover{border-color:#0006}.user-avatar{object-fit:cover;width:100%;height:100%}.user-avatar-initials{color:#555;font-size:.95rem;font-weight:600;line-height:1}.user-menu-overlay{z-index:10;position:fixed;inset:0}.user-menu-dropdown{z-index:11;background:#fff;border-radius:8px;min-width:200px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 4px 16px #00000026}.user-menu-info{padding:12px 16px}.user-menu-name{color:#222;text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:.9rem;font-weight:600;overflow:hidden}.user-menu-email{color:#888;text-overflow:ellipsis;white-space:nowrap;margin:2px 0 0;font-size:.78rem;overflow:hidden}.user-menu-divider{border:none;border-top:1px solid #eee;margin:0}.user-menu-item{text-align:left;color:#333;cursor:pointer;background:0 0;border:none;width:100%;padding:10px 16px;font-size:.88rem;transition:background-color .1s;display:block}.user-menu-item:hover{background-color:#f5f0e8}.user-menu-item--logout{color:#c0392b}.notif-menu{position:relative}.notif-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:1.1rem;line-height:1;transition:background-color .15s;position:relative}.notif-btn:hover{background:#0000000f}.notif-badge{color:#fff;text-align:center;background:#e74c3c;border-radius:8px;min-width:14px;padding:1px 4px;font-size:.65rem;font-weight:700;line-height:1.4;position:absolute;top:0;right:0;transform:translate(30%,-20%)}.notif-overlay{z-index:10;position:fixed;inset:0}.notif-dropdown{z-index:11;background:#fff;border-radius:10px;width:300px;max-height:400px;position:absolute;top:calc(100% + 8px);right:0;overflow-y:auto;box-shadow:0 4px 20px #00000026}.notif-header{color:#444;border-bottom:1px solid #f0ebe0;padding:12px 16px 8px;font-size:.85rem;font-weight:700}.notif-empty{text-align:center;color:#aaa;margin:0;padding:24px 16px;font-size:.85rem}.notif-list{margin:0;padding:0;list-style:none}.notif-item{border-bottom:1px solid #f5f0e8;align-items:flex-start;gap:10px;padding:12px 16px;transition:background-color .1s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:#fdf6ec}.notif-item:hover{background:#faf7f2}.notif-icon{flex-shrink:0;margin-top:1px;font-size:1rem}.notif-body{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.notif-text{color:#333;font-size:.82rem;line-height:1.4}.notif-time{color:#aaa;font-size:.74rem}.notif-clip-thumb{object-fit:cover;background:#e8e4d8;border-radius:5px;flex-shrink:0;width:44px;height:44px}.friend-book-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.friend-book-modal{background:#f5f0e8;border-radius:12px;flex-direction:column;width:min(860px,95vw);max-height:85vh;display:flex;overflow:hidden;box-shadow:0 8px 32px #0003}.friend-book-header{color:#fff;background:#2c5f2e;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.friend-book-identity{align-items:center;gap:10px;display:flex}.friend-book-avatar{object-fit:cover;border:2px solid #ffffff80;border-radius:50%;width:32px;height:32px}.friend-book-initials{background:#fff3;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.9rem;font-weight:700;display:flex}.friend-book-name{font-size:.95rem;font-weight:600}.friend-book-close{color:#fffc;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:1.1rem;transition:color .1s}.friend-book-close:hover{color:#fff}.friend-book-body{flex:1;padding:20px;overflow-y:auto}.friend-tag-filter{scrollbar-width:none;background:#2c5f2e;border-bottom:1px solid #ffffff26;flex-shrink:0;gap:8px;padding:10px 16px;display:flex;overflow-x:auto}.friend-tag-filter::-webkit-scrollbar{display:none}.friend-tag-btn{color:#ffffffbf;white-space:nowrap;cursor:pointer;background:0 0;border:1px solid #fff6;border-radius:20px;flex-shrink:0;align-items:center;padding:4px 14px;font-size:.82rem;transition:background-color .15s,color .15s;display:flex}.friend-tag-btn:hover{color:#fff;background:#ffffff1f}.friend-tag-btn.active{color:#fff;background:#ffffff4d;border-color:#ffffffd9;font-weight:600}.friend-book-loading,.friend-book-empty{text-align:center;color:#888;padding:40px 0}.friend-clips-grid{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.friend-clip-card{aspect-ratio:1;background:#e8e4d8;border-radius:6px;position:relative;overflow:hidden;box-shadow:0 2px 6px #0000001f}.friend-clip-img{object-fit:cover;width:100%;height:100%;display:block}.friend-clip-like{cursor:pointer;color:#888;background:#ffffffe0;border:none;border-radius:12px;padding:3px 8px;font-size:.78rem;transition:background-color .1s,color .1s;position:absolute;bottom:6px;right:6px}.friend-clip-like.liked{color:#e74c3c}.friend-clip-like:hover{background:#fff}.friends-page{background:#f5f0e8;flex-direction:column;flex:1;display:flex}.fp-tabs{background:#f5f0e8;border-bottom:1px solid #ddd8cc;gap:4px;padding:12px 24px 0;display:flex}.fp-tab{color:#666;cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:6px 6px 0 0;padding:8px 18px;font-size:.88rem;transition:background-color .1s,color .1s;position:relative}.fp-tab:hover{color:#2c5f2e;background:#2c5f2e14}.fp-tab.active{color:#2c5f2e;background:#fff;font-weight:600;box-shadow:inset 0 -2px #2c5f2e}.fp-badge-count{color:#fff;vertical-align:middle;background:#e74c3c;border-radius:10px;margin-left:4px;padding:1px 5px;font-size:.7rem;font-weight:700;display:inline-block}.fp-content{flex:1;padding:24px;overflow-y:auto}.fp-section{max-width:560px;margin:0 auto}.fp-search-input{color:#222;box-sizing:border-box;background:#fff;border:1px solid #d0cbbf;border-radius:8px;outline:none;width:100%;margin-bottom:16px;padding:10px 16px;font-size:.95rem;transition:border-color .15s}.fp-search-input:focus{border-color:#2c5f2e}.fp-user-list{flex-direction:column;gap:8px;display:flex}.fp-user-row{background:#fff;border-radius:10px;align-items:center;gap:12px;padding:12px 16px;display:flex;box-shadow:0 1px 4px #0000000f}.fp-user-row--clickable{cursor:pointer;transition:background-color .1s}.fp-user-row--clickable:hover{background:#faf7f2}.fp-avatar{object-fit:cover;border-radius:50%;flex-shrink:0}.fp-avatar-initials{color:#666;background:#d8d4c8;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.fp-user-name{color:#222;text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.92rem;font-weight:500;overflow:hidden}.fp-user-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.fp-btn{cursor:pointer;border:none;border-radius:6px;padding:6px 14px;font-size:.84rem;transition:background-color .1s}.fp-btn--primary{color:#fff;background:#2c5f2e}.fp-btn--primary:hover{background:#245024}.fp-btn--ghost{color:#555;background:#f0ebe0}.fp-btn--ghost:hover{background:#e8e2d4}.fp-btn--sm{padding:4px 10px;font-size:.78rem}.fp-badge{border-radius:10px;padding:3px 10px;font-size:.78rem;font-weight:600}.fp-badge--friend{color:#2c5f2e;background:#e8f5e9}.fp-badge--pending{color:#e67e22;background:#fff3e0}.fp-badge--received{color:#1565c0;background:#e3f2fd}.fp-hint{color:#888;text-align:center;padding:32px 0;font-size:.88rem}.fp-hint-sm{color:#aaa;font-size:.78rem}.home{background-color:#f5f0e8;flex-direction:column;min-height:100vh;display:flex}.home-header{background-color:#ede8d8;border-bottom:1px solid #0000001a;justify-content:space-between;align-items:center;padding:15px 24px;display:flex}.home-header-left{align-items:center;gap:20px;display:flex}.home-nav{gap:4px;display:flex}.home-nav-btn{color:#666;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;padding:6px 14px;font-size:.88rem;transition:background-color .15s,color .15s}.home-nav-btn:hover{color:#333;background:#0000000f}.home-nav-btn.active{color:#2c4a6e;background:#00000014;border-color:#2c4a6e59;font-weight:600}.home-logo{cursor:pointer;width:auto;height:60px;display:block}.home-main{flex-direction:column;flex:1;align-items:center;padding:16px 0;display:flex}.loading-text{color:#888;margin-top:48px}@media (width<=767px){.home-header{padding:18px 12px}.home-logo{height:45px}.home-header-left{gap:8px}.home-nav-btn{padding:5px 10px;font-size:.82rem}.home-main{padding:1px 0}.legal-page{background-color:#f5f0e8;flex-direction:column;min-height:100vh;display:flex}.legal-header{background-color:#ede8d8;border-bottom:1px solid #0000001a;padding:16px 24px}.legal-back-btn{color:#6b5344;cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:.9rem;display:flex}.legal-back-btn:hover{color:#4a3728;text-decoration:underline}.legal-content{text-align:left;width:100%;max-width:720px;margin:0 auto;padding:48px 24px 80px}.legal-content h1{color:#4a3728;margin:0 0 8px;font-size:1.6rem;font-weight:700}.legal-updated{color:#999;margin:0 0 40px;font-size:.85rem}.legal-content h2{color:#4a3728;margin:36px 0 10px;font-size:1.05rem;font-weight:700}.legal-content p,.legal-content li{color:#555;margin:0 0 8px;font-size:.9rem;line-height:1.9}.legal-content ul{text-align:left;margin:0 0 8px;padding-left:0;list-style:none}.legal-content li{text-indent:-1.2em;padding-left:1.2em}.legal-content li:before{content:"・"}.contact-form{flex-direction:column;gap:20px;margin-top:32px;display:flex}.contact-field{flex-direction:column;gap:6px;display:flex}.contact-field label{color:#4a3728;font-size:.88rem;font-weight:600}.contact-field input,.contact-field textarea{color:#333;background:#fff;border:1px solid #d0c9be;border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:.9rem;transition:border-color .15s}.contact-field input:focus,.contact-field textarea:focus{border-color:#4a3728}.contact-field textarea{resize:vertical;min-height:140px}.contact-submit-btn{color:#fff;cursor:pointer;background:#4a3728;border:none;border-radius:8px;align-self:flex-start;padding:10px 32px;font-size:.9rem;font-weight:600;transition:background-color .15s}.contact-submit-btn:hover{background:#3a2a1e}.contact-submit-btn:disabled{cursor:not-allowed;background:#aaa}.contact-success{color:#2e6e2e;background:#eaf4ea;border:1px solid #b2d8b2;border-radius:8px;padding:16px 20px;font-size:.9rem}.contact-error{color:#b94a4a;background:#fdf0f0;border:1px solid #f0b8b8;border-radius:8px;padding:16px 20px;font-size:.9rem}@media (width<=767px){.legal-content{padding:32px 16px 60px}.legal-content h1{font-size:1.3rem}.contact-submit-btn{text-align:center;align-self:stretch}}}
