:root{--bg: #080808;--surface: #111111;--surface-2: #181818;--surface-3: #242424;--border: #202020;--border-2: #333333;--text: #f0f0f0;--text-2: #888888;--text-3: #555555;--accent: #9d7cf8;--accent-hover: #b49bff;--accent-dim: rgba(157, 124, 248, .12);--red: #ff6b6b;--green: #4caf7d;--radius: 8px;--radius-sm: 4px;--radius-lg: 12px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit;border:none;background:none}input,textarea{font-family:inherit}.spinner{width:20px;height:20px;border:2px solid var(--border-2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;display:inline-block}.center-spinner{display:block;margin:60px auto}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius);font-size:14px;font-weight:500;transition:background .15s,color .15s,opacity .15s;cursor:pointer;border:none}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-ghost{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.btn-full{width:100%;justify-content:center}.btn-lg{padding:13px 32px;font-size:15px}.btn-back{background:none;color:var(--text-2);font-size:13px;padding:4px 0;margin-bottom:24px;cursor:pointer;display:inline-block}.btn-back:hover{color:var(--text)}.input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:10px 14px;font-size:14px;outline:none;transition:border-color .15s}.input:focus{border-color:var(--accent)}.input::placeholder{color:var(--text-3)}.input-sm{padding:7px 10px;font-size:13px}.textarea{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:12px 14px;font-size:14px;outline:none;resize:vertical;line-height:1.65;transition:border-color .15s}.textarea:focus{border-color:var(--accent)}.textarea::placeholder{color:var(--text-3)}.input-wrap{position:relative;display:flex;align-items:center}.input-prefix{position:absolute;left:14px;color:var(--text-2);font-size:14px;pointer-events:none}.input-prefixed{padding-left:28px}.input-hint{font-size:12px;color:var(--text-3);margin-top:4px}.tag{display:inline-flex;align-items:center;gap:4px;background:var(--accent-dim);color:var(--accent-hover);padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;letter-spacing:.01em}.tag-removable button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:15px;line-height:1;padding:0;margin-left:2px}.tag-removable button:hover{color:var(--red)}.error-msg{color:var(--red);font-size:13px;margin-top:8px}.success-msg{color:var(--green);font-size:13px;margin-top:8px}.nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:56px;background:#080808eb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}.nav-logo{font-family:Georgia,Times New Roman,serif;font-size:19px;letter-spacing:.04em;color:var(--text);font-weight:400}.nav-right{display:flex;align-items:center;gap:12px}.nav-menu{position:relative}.nav-user-btn{background:none;border:1px solid var(--border);color:var(--text-2);border-radius:var(--radius);padding:6px 13px;font-size:13px;cursor:pointer;transition:border-color .15s,color .15s}.nav-user-btn:hover{border-color:var(--border-2);color:var(--text)}.nav-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);min-width:168px;overflow:hidden;box-shadow:0 8px 28px #0009;z-index:200}.nav-dropdown a,.nav-dropdown button{display:block;width:100%;padding:10px 16px;font-size:14px;color:var(--text-2);text-align:left;cursor:pointer;transition:background .1s,color .1s}.nav-dropdown a:hover,.nav-dropdown button:hover{background:var(--surface-3);color:var(--text)}.page{max-width:680px;margin:0 auto;padding:40px 24px 100px}.landing{min-height:100vh;display:flex;flex-direction:column}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:22px 48px}.landing-hero{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 40px 64px}.landing-title{font-family:Georgia,Times New Roman,serif;font-size:clamp(2.8rem,7vw,5rem);font-weight:400;line-height:1.12;margin-bottom:28px;letter-spacing:-.01em}.landing-sub{font-size:17px;color:var(--text-2);line-height:1.75;max-width:400px;margin-bottom:44px}.landing-features{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;padding:64px 48px;border-top:1px solid var(--border)}.feature{display:flex;flex-direction:column;gap:10px}.feature-icon{font-size:22px;color:var(--accent)}.feature h3{font-size:14px;font-weight:600}.feature p{font-size:13px;color:var(--text-2);line-height:1.7}.landing-footer{display:flex;justify-content:space-between;padding:20px 48px;border-top:1px solid var(--border);font-size:13px;color:var(--text-3);font-family:Georgia,serif}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:360px}.auth-logo{font-family:Georgia,serif;font-size:30px;font-weight:400;text-align:center;margin-bottom:8px;display:block}.auth-sub{text-align:center;color:var(--text-2);font-size:14px;margin-bottom:36px}.auth-form{display:flex;flex-direction:column;gap:12px}.auth-switch{display:block;margin-top:20px;width:100%;text-align:center;font-size:13px;color:var(--text-2);cursor:pointer;background:none;border:none;padding:8px}.auth-switch:hover{color:var(--text)}.constellation-wrap{width:100%;border-radius:var(--radius-lg);overflow:hidden;background:#080808;border:1px solid var(--border)}.constellation-svg{width:100%;height:auto;display:block}.profile-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px}.profile-info h2{font-size:20px;font-weight:600}.view-public-link{font-size:13px;color:var(--text-3);margin-top:4px;display:inline-block;transition:color .15s}.view-public-link:hover{color:var(--accent)}.map-section{margin-bottom:32px}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:28px}.tab{padding:9px 18px;font-size:14px;color:var(--text-2);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-1px;cursor:pointer;transition:color .15s,border-color .15s}.tab.active{color:var(--text);border-bottom-color:var(--accent)}.tab:hover:not(.active){color:var(--text)}.entries-list{display:flex;flex-direction:column;gap:12px}.entry-card{display:flex;gap:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;transition:border-color .15s}.entry-card:hover{border-color:var(--border-2)}.entry-private{opacity:.7}.entry-cover{width:58px;height:86px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--surface-3)}.entry-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:7px}.entry-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.type-badge{font-size:10px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;padding:2px 7px;border-radius:3px;flex-shrink:0}.type-book{background:#63b0911f;color:#5db38a}.type-movie{background:var(--accent-dim);color:var(--accent)}.entry-title{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry-interpretation{font-size:13px;color:var(--text-2);line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.entry-tags{display:flex;flex-wrap:wrap;gap:5px}.entry-actions{display:flex;gap:8px;margin-top:2px;align-items:center}.btn-toggle{font-size:12px;padding:3px 10px;border-radius:20px;background:none;border:1px solid var(--border);color:var(--text-3);cursor:pointer;transition:border-color .15s,color .15s}.btn-toggle.public{border-color:#4caf7d66;color:var(--green)}.btn-toggle:hover{border-color:var(--accent);color:var(--accent)}.btn-delete{font-size:12px;padding:3px 10px;border-radius:20px;background:none;border:1px solid transparent;color:var(--text-3);cursor:pointer;transition:border-color .15s,color .15s}.btn-delete:hover{border-color:#ff6b6b66;color:var(--red)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3px}.photo-item{position:relative;aspect-ratio:1;overflow:hidden;background:var(--surface);cursor:pointer}.photo-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s}.photo-item:hover img{transform:scale(1.03)}.photo-lock{position:absolute;top:7px;right:7px;font-size:13px;background:#080808b3;border-radius:4px;padding:2px 4px;line-height:1}.photo-menu{position:absolute;top:0;right:0;bottom:0;left:0;background:#080808ed;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;padding:16px}.photo-menu button{width:100%;padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;background:var(--surface-2);color:var(--text);border:1px solid var(--border);cursor:pointer;transition:background .1s}.photo-menu button:hover{background:var(--surface-3)}.photo-menu button.danger{color:var(--red);border-color:#ff6b6b40}.photo-caption{font-size:12px;color:var(--text-2);text-align:center;max-width:100%}.add-page{padding-top:48px}.add-inner{max-width:540px;margin:0 auto}.add-type{text-align:center}.add-type h2{font-family:Georgia,serif;font-size:24px;font-weight:400;margin-bottom:36px}.type-choices{display:flex;gap:14px}.type-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-2);font-size:14px;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.type-btn:hover{border-color:var(--accent);color:var(--text);background:var(--surface-2)}.type-icon{font-size:28px}.add-search h2,.add-write h2,.add-photo h2{font-family:Georgia,serif;font-size:22px;font-weight:400;margin-bottom:22px}.search-results{margin-top:10px;display:flex;flex-direction:column;gap:1px}.search-result{display:flex;align-items:center;gap:14px;padding:10px 12px;border-radius:var(--radius);background:none;border:none;cursor:pointer;width:100%;text-align:left;color:var(--text);transition:background .1s}.search-result:hover{background:var(--surface-2)}.search-result img{width:40px;height:58px;object-fit:cover;border-radius:3px;flex-shrink:0;background:var(--surface-3)}.no-cover{width:40px;height:58px;background:var(--surface-3);border-radius:3px;flex-shrink:0}.result-title{font-size:14px;font-weight:500}.result-sub{font-size:12px;color:var(--text-2);margin-top:2px}.selected-source{display:flex;align-items:center;gap:14px;margin-bottom:28px;padding:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.source-thumb{width:46px;height:68px;object-fit:cover;border-radius:4px;flex-shrink:0;background:var(--surface-3)}.source-title{font-size:15px;font-weight:600}.source-sub{font-size:13px;color:var(--text-2);margin-top:2px}.write-section{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.field-label{font-size:13px;color:var(--text-2);font-weight:500}.char-count{font-size:11px;color:var(--text-3)}.tags-section{display:flex;flex-direction:column;gap:14px;margin-top:20px;padding:18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.tag-editor{display:flex;flex-direction:column;gap:10px}.tags-row{display:flex;flex-wrap:wrap;gap:6px;min-height:28px}.tag-input-row{display:flex;gap:8px}.tag-input-row .input{flex:1}.photo-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:64px 24px;border:2px dashed var(--border-2);border-radius:var(--radius-lg);cursor:pointer;color:var(--text-2);transition:border-color .15s,color .15s;margin-bottom:20px;font-size:14px}.photo-drop:hover{border-color:var(--accent);color:var(--text)}.photo-drop-icon{font-size:40px;color:var(--text-3)}.photo-preview-wrap{margin-bottom:20px;display:flex;flex-direction:column;gap:12px}.photo-preview{width:100%;max-height:420px;object-fit:contain;border-radius:var(--radius);background:var(--surface)}.settings-page h2{font-family:Georgia,serif;font-size:26px;font-weight:400;margin-bottom:40px}.settings-section{margin-bottom:44px}.settings-section h3{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:12px}.settings-sub{font-size:13px;color:var(--text-3);margin-bottom:16px;line-height:1.6}.toggle-list{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;font-size:14px;border-bottom:1px solid var(--border);transition:background .1s}.toggle-row:last-child{border-bottom:none}.toggle-row:hover{background:var(--surface)}.toggle{width:44px;height:24px;border-radius:12px;border:none;cursor:pointer;position:relative;transition:background .2s;padding:0;flex-shrink:0}.toggle.on{background:var(--accent)}.toggle.off{background:var(--surface-3)}.toggle:disabled{opacity:.5;cursor:not-allowed}.toggle-thumb{position:absolute;top:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .2s;pointer-events:none}.toggle.on .toggle-thumb{left:23px}.toggle.off .toggle-thumb{left:3px}.settings-row-info{font-size:14px;color:var(--text-2);padding:5px 0}.empty-state{text-align:center;padding:64px 24px;display:flex;flex-direction:column;align-items:center;gap:16px}.empty-state p{color:var(--text-2);font-size:15px}@media (max-width: 600px){.page{padding:28px 16px 100px}.type-choices{flex-direction:column}.nav{padding:0 16px}.landing-nav{padding:18px 24px}.landing-hero{padding:60px 24px 48px}.landing-features{grid-template-columns:1fr;padding:48px 24px}.landing-footer{padding:18px 24px}.entry-card{flex-direction:column}.entry-cover{width:100%;height:180px}.photo-grid{grid-template-columns:repeat(3,1fr);gap:2px}}
