*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand: #4f6ef7;--brand-dark: #3a56d4;--danger: #e04040;--danger-dark: #c03030;--bg: #f5f7ff;--surface: #ffffff;--border: #dde1f0;--text: #1a1d2e;--muted: #6b7194;--radius: 10px}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;overflow-x:hidden}#root{min-height:100dvh;display:flex;flex-direction:column}.center-screen{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2rem;width:100%;max-width:420px;display:flex;flex-direction:column;gap:1.25rem;box-shadow:0 4px 24px #4f6ef714}.logo{font-size:1.6rem;font-weight:700;color:var(--brand);text-align:center;letter-spacing:-.5px}.logo-link{text-decoration:none;cursor:pointer}.logo-link:hover .logo{opacity:.8}h2{font-size:1.1rem;font-weight:600;text-align:center;color:var(--text)}.tabs{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.tab{flex:1;padding:.55rem 1rem;background:transparent;border:none;cursor:pointer;font-size:.9rem;font-weight:500;color:var(--muted);transition:background .15s,color .15s}.tab:hover{background:var(--bg);color:var(--text)}.tab.active{background:var(--brand);color:#fff}form{display:flex;flex-direction:column;gap:.9rem}label{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;font-weight:500;color:var(--muted)}input{padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s}input:focus{border-color:var(--brand);background:#fff}.btn{padding:.65rem 1.25rem;border:none;border-radius:6px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.primary{background:var(--brand);color:#fff}.btn.primary:hover:not(:disabled){background:var(--brand-dark)}.btn.danger{background:var(--danger);color:#fff}.btn.danger:hover:not(:disabled){background:var(--danger-dark)}.btn.danger-outline{background:transparent;color:var(--danger);border:1px solid var(--danger)}.btn.danger-outline:hover:not(:disabled){background:var(--danger);color:#fff}.banner{padding:.6rem .85rem;border-radius:6px;font-size:.875rem}.banner.error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}.account-deleted-banner{max-width:420px;margin:1rem auto 0;text-align:center}.banner.info{background:#eff6ff;color:var(--brand-dark);border:1px solid #bfdbfe}.banner.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.banner-dismissable{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.banner-dismiss{background:none;border:none;cursor:pointer;font-size:1.1rem;line-height:1;color:inherit;opacity:.6;padding:0;flex-shrink:0}.banner-dismiss:hover{opacity:1}.check-inbox-card,.verify-email-card{text-align:center;gap:.75rem}.check-inbox-card h2,.verify-email-card h2{font-size:1.35rem}.check-inbox-detail,.verify-email-detail{color:var(--muted);font-size:.95rem;line-height:1.5}.check-inbox-hint{color:var(--muted);font-size:.85rem}.verify-email-banner{margin-bottom:.5rem}.verify-email-feedback{font-weight:400}.forgot-password-link{margin-top:.25rem}.forgot-password-detail,.reset-password-detail{color:var(--muted);font-size:.95rem;line-height:1.5}.forgot-password-sent{text-align:center;display:flex;flex-direction:column;gap:.75rem}.forgot-password-sent h2{font-size:1.35rem}.reset-password-card{text-align:center;gap:.75rem}.reset-password-card h2{font-size:1.35rem}.reset-password-card form{text-align:left}.link-btn{background:none;border:none;color:var(--brand);cursor:pointer;font-size:.9rem;padding:0;text-decoration:underline}.link-btn:hover{color:var(--brand-dark)}.email-notifications-toggle{display:flex;align-items:center;gap:.5rem}.toggle-btn{position:relative;width:44px;height:24px;border-radius:12px;border:none;cursor:pointer;transition:background .2s;padding:0;flex-shrink:0}.toggle-btn.on{background:var(--brand)}.toggle-btn.off{background:var(--border)}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.toggle-knob{position:absolute;top:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:left .2s}.toggle-btn.on .toggle-knob{left:22px}.toggle-btn.off .toggle-knob{left:2px}.toggle-label{font-size:.875rem;color:var(--muted)}.upload-progress-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;pointer-events:none;width:100%}.upload-progress-label{font-size:.7rem;color:var(--muted)}.upload-progress-track{width:80px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--brand);border-radius:2px;transition:width .1s linear}.upload-progress-meta{font-size:.65rem;color:var(--muted);text-align:center;line-height:1.2}.upload-compression-meta{font-size:.65rem;color:var(--accent);text-align:center;line-height:1.2}.cover-upload-progress{margin-top:.4rem;display:flex;align-items:center;gap:.5rem}.cover-upload-progress .upload-progress-track{width:120px}.user-info{display:flex;flex-direction:column;gap:.5rem;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;background:var(--bg)}.field{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.label{font-weight:600;color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.muted{color:var(--muted)}.field-error{font-size:.8rem;color:var(--danger);margin-top:-.4rem}.field-hint{font-size:.8rem;color:var(--muted);margin-top:-.4rem}.card.wide{max-width:680px}.btn.sm{padding:.3rem .65rem;font-size:.8rem}.btn.ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn.ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn.ghost.danger{color:var(--danger);border-color:#fecaca}.btn.ghost.danger:hover:not(:disabled){background:#fef2f2}.btn.accent{background:linear-gradient(135deg,#7c3aed,#4f6ef7);color:#fff;border:none}.btn.accent:hover:not(:disabled){background:linear-gradient(135deg,#6d28d9,#3a56d4);opacity:.95}textarea{padding:.6rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s;font-family:inherit;resize:vertical}textarea:focus{border-color:var(--brand);background:#fff}.strand-section{border:1px solid var(--border);border-radius:var(--radius);padding:1rem;background:var(--bg);display:flex;flex-direction:column;gap:.75rem}.strand-empty-hint{font-size:.875rem}.strand-sort-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.85rem;color:var(--muted)}.strand-sort-row select{font-size:.85rem;padding:.2rem .4rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer}.strand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.875rem;margin-top:.75rem}.strand-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:0;cursor:pointer;text-align:left;display:flex;flex-direction:column;overflow:hidden;transition:border-color .18s,box-shadow .18s,transform .18s;box-shadow:0 1px 4px #1a1d2e0f}.strand-tile:hover{border-color:var(--brand);box-shadow:0 6px 20px #4f6ef724;transform:translateY(-2px)}.strand-tile-cover{width:100%;height:120px;overflow:hidden;flex-shrink:0}.strand-tile-cover img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .25s}.strand-tile:hover .strand-tile-cover img{transform:scale(1.04)}.strand-tile-placeholder{width:100%;height:120px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8ecff,#d4dbff);font-size:2.5rem}.strand-tile-body{padding:.75rem .875rem;display:flex;flex-direction:column;gap:.3rem;flex:1}.strand-tile-title{font-weight:700;font-size:.9rem;color:var(--text);line-height:1.3}.strand-tile-desc{font-size:.78rem;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.strand-tile-footer{display:flex;align-items:center;gap:.6rem;margin-top:auto;padding-top:.4rem}.strand-tile-meta{font-size:.72rem;color:var(--muted)}.strand-form-actions{display:flex;gap:.5rem}.strand-detail-hero{width:100%;height:200px;overflow:hidden;border-radius:var(--radius);flex-shrink:0}.strand-detail-hero img{width:100%;height:100%;object-fit:cover;display:block}.strand-detail-placeholder{width:100%;height:140px;display:flex;align-items:center;justify-content:center;font-size:3rem;background:linear-gradient(135deg,#e8ecff,#d4dbff);border-radius:var(--radius)}.strand-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.4rem}.strand-toolbar-actions{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.delete-confirm{padding:1rem;border-radius:var(--radius);background:var(--surface);border:1px solid var(--color-danger, #e53e3e);margin-block:.75rem}.delete-confirm-text{margin:0 0 .75rem}.strand-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.strand-header-actions{display:flex;gap:.4rem}.strand-header-title{display:flex;flex-direction:column;gap:.2rem}.strand-header-desc{font-size:.85rem;color:var(--color-muted)}.strand-edit-form{margin-bottom:.75rem}.profile-edit-form{display:flex;flex-direction:column;gap:.75rem;border:1px solid var(--border);border-radius:var(--radius);padding:1rem;background:var(--bg)}.btn.share-on{background:#d1fae5;color:#065f46;border:1px solid #6ee7b7}.btn.share-on:hover:not(:disabled){background:#fef2f2;color:var(--danger);border-color:#fecaca}.share-url-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;margin-bottom:.25rem;flex-wrap:wrap}.share-url{flex:1;font-size:.8rem;color:var(--brand-dark);word-break:break-all;font-family:ui-monospace,monospace}.share-rotate-note{font-size:.75rem}.btn.profile-on{background:#ede9fe;color:#5b21b6;border:1px solid #c4b5fd}.btn.profile-on:hover:not(:disabled){background:#fef2f2;color:var(--danger);border-color:#fecaca}.profile-link{color:var(--brand);font-size:.875rem;text-decoration:none}.profile-link:hover{text-decoration:underline}.profile-heading{margin-bottom:1rem}.profile-stats{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem;display:flex;flex-direction:column;gap:.75rem}.profile-stats-numbers{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:.5rem}@media(max-width:480px){.profile-stats-numbers{grid-template-columns:repeat(6,1fr);gap:.75rem 0}.profile-stats-numbers .profile-stat:nth-child(1){grid-column:1 / span 2}.profile-stats-numbers .profile-stat:nth-child(2){grid-column:3 / span 2}.profile-stats-numbers .profile-stat:nth-child(3){grid-column:5 / span 2}.profile-stats-numbers .profile-stat:nth-child(4){grid-column:2 / span 2}.profile-stats-numbers .profile-stat:nth-child(5){grid-column:4 / span 2}}.profile-stat{display:flex;flex-direction:column;align-items:center;gap:.1rem}.profile-stat-value{font-size:1.5rem;font-weight:700;color:var(--brand);line-height:1}.profile-stat-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.profile-stat-btn{background:none;border:none;cursor:pointer;padding:0;text-align:center}.profile-stat-btn:hover .profile-stat-value{text-decoration:underline}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal-content{max-width:420px;width:90%}.modal-card{background:var(--surface);border-radius:var(--radius);padding:1.5rem;min-width:280px;max-height:60vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.modal-header h3{margin:0}.delete-account-warning{margin-bottom:1rem;line-height:1.5}.delete-account-warning p+p{margin-top:.5rem}.delete-account-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem}.field-label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem;color:var(--text)}.modal-user-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:0}.modal-user-row{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--border)}.modal-user-row:last-child{border-bottom:none}.modal-user-avatar{width:2rem;height:2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0;-webkit-user-select:none;user-select:none}.modal-user-name{flex:1;display:flex;align-items:center;gap:.6rem;font-weight:500;color:var(--text);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-user-name:hover{color:var(--brand);text-decoration:underline}.leaderboard-btn{display:block;width:100%;margin-top:.75rem;padding:.75rem 1rem;font-size:1rem;font-weight:700;text-align:center;text-decoration:none;background:linear-gradient(135deg,#f6c90e,#e0a800);color:#1a1a1a;border-radius:var(--radius);border:none;cursor:pointer;transition:filter .15s ease}.leaderboard-btn:hover{filter:brightness(1.08);text-decoration:none}.leaderboard-hint{margin-bottom:1rem}.leaderboard-table{width:100%;border-collapse:collapse;margin-top:1rem}.leaderboard-table th,.leaderboard-table td{padding:.6rem .75rem;text-align:left;border-bottom:1px solid var(--border)}.leaderboard-table th{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}.leaderboard-rank{width:3.5rem;text-align:center!important}.leaderboard-count{width:5rem;text-align:right!important}.leaderboard-follow{width:6rem;text-align:right!important}.leaderboard-name-cell{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text);font-weight:500}.leaderboard-name-cell:hover{color:var(--brand);text-decoration:underline}.leaderboard-row:hover{background:var(--surface)}.leaderboard-row-self{background:var(--surface);font-weight:600}.profile-stats-continents{display:flex;flex-direction:column;gap:.35rem;border-top:1px solid var(--border);padding-top:.75rem}.profile-continent{display:flex;gap:.5rem;align-items:baseline;font-size:.85rem}.profile-continent-name{font-weight:600;min-width:5rem}.profile-continents-link{display:block;text-align:center;font-size:.8rem;font-weight:500;color:var(--brand);text-decoration:none;border-top:1px solid var(--border);padding-top:.75rem;letter-spacing:.01em}.profile-continents-link:hover{color:var(--brand-dark)}.continent-view-header{display:flex;flex-direction:column;gap:.25rem}.continent-back-link{font-size:.85rem;color:var(--brand);text-decoration:none}.continent-back-link:hover{text-decoration:underline}.world-map-hint{text-align:center;font-size:.85rem;margin-top:.5rem}.world-map-container{width:100%;margin-bottom:1rem;border-radius:var(--radius);overflow:hidden;background:var(--bg-muted, #f5f5f5)}.world-map-svg{display:block;width:100%;height:auto}.world-map-country{fill:var(--border);stroke:var(--bg);stroke-width:.5;transition:fill .2s}.world-map-country.visited{fill:var(--brand)}.continent-world-total{text-align:center;padding:.75rem 0;border-bottom:1px solid var(--border);margin-bottom:.25rem;font-size:.95rem}.profile-continent-countries{font-size:.8rem;flex:1}.profile-continent-meta{font-size:.75rem;white-space:nowrap}.profile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}.profile-card-clickable{cursor:pointer;transition:box-shadow .15s ease,border-color .15s ease}.profile-card-clickable:hover,.profile-card-clickable:focus-visible{border-color:var(--color-primary, #4f6ef7);box-shadow:0 2px 8px #0000001a}.profile-card-clickable:focus-visible{outline:2px solid var(--color-primary, #4f6ef7);outline-offset:2px}.profile-card-cover{width:100%;height:140px;object-fit:cover}.profile-card-title-hero{width:100%;height:140px;background:var(--surface-alt, #f0f2f5);display:flex;align-items:center;justify-content:center;padding:1rem;text-align:center;font-size:1.05rem;font-weight:700;color:var(--text);line-height:1.3}.profile-card-body{padding:.75rem;display:flex;flex-direction:column;gap:.25rem;flex:1}.profile-card-footer{display:flex;flex-direction:column;gap:.25rem;margin-top:auto;padding-top:.5rem}.profile-card-title{font-weight:600;font-size:.95rem}.profile-card-desc{font-size:.8rem;color:var(--muted)}.profile-card-meta{font-size:.75rem}.profile-card-link{font-size:.8rem;color:var(--brand);text-decoration:none;margin-top:.25rem}.profile-card-link:hover{text-decoration:underline}.shared-desc{font-size:.9rem;margin-top:.25rem}.shared-header{display:flex;justify-content:space-between;align-items:center}.shared-header-actions{display:flex;gap:.5rem}.shared-tagged{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}.shared-tagged-label{font-size:.8rem;color:var(--muted)}.shared-tagged-chip{font-size:.8rem;font-weight:500;color:var(--brand);background:#4f6ef714;border-radius:999px;padding:.15rem .6rem;text-decoration:none}.shared-tagged-chip:hover{background:#4f6ef729}.shared-co-authors{display:flex;align-items:center;flex-wrap:wrap;gap:.4rem;margin-top:.6rem}.shared-co-authors-label{font-size:.8rem;color:var(--muted)}.shared-co-author-chip{display:inline-flex;align-items:center;gap:.3rem;font-size:.8rem;font-weight:500;color:var(--brand);background:#4f6ef714;border-radius:999px;padding:.15rem .6rem .15rem .2rem;text-decoration:none}.shared-co-author-chip:hover{background:#4f6ef729}.shared-co-author-avatar{width:1.2rem;height:1.2rem;border-radius:50%;color:#fff;font-size:.6rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.step-list{display:flex;flex-direction:column;gap:.5rem}.step-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem}.step-list-actions{display:flex;gap:.4rem;align-items:center;position:relative;flex-wrap:wrap}.step-actions-progress{position:absolute;bottom:0;left:0;right:0;height:4px;background:var(--border);overflow:hidden}.step-actions-progress-fill{height:100%;background:linear-gradient(90deg,var(--brand),var(--brand-dark, #3a56d4));transition:width .4s ease-out}.step-empty{font-size:.875rem;padding:.5rem 0}.step-item{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;padding:.6rem 0;border-bottom:1px solid var(--border)}.step-item:last-of-type{border-bottom:none}.step-info{display:flex;flex-direction:column;gap:.2rem;flex:1;min-width:0}.step-title{font-weight:600;font-size:.9rem}.step-date{font-size:.8rem}.step-desc{font-size:.85rem;white-space:pre-wrap}.step-actions{display:flex;gap:.4rem;flex-shrink:0}.step-edit-wrapper{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.step-edit-preview{display:flex;flex-wrap:wrap;gap:2px;background:#000;height:240px;overflow:hidden;border-radius:6px}.step-edit-preview-media{flex:1 1 auto;width:100%;height:240px;object-fit:cover;display:block}.step-edit-wrapper .step-form{border:none;border-radius:0;border-top:1px solid var(--border)}.step-edit-remaining{padding:.5rem .75rem;font-size:.8rem;background:var(--primary-faint, rgba(79, 110, 247, .08));border-bottom:1px solid var(--border);margin:0}.bulk-edit-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:300;padding:1rem}.bulk-edit-modal{background:var(--surface);border-radius:var(--radius);padding:1.25rem;width:90%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 30px #0003;animation:bulk-edit-pop .2s ease-out}.bulk-edit-body{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.bulk-edit-footer{display:flex;gap:.5rem;padding-top:.75rem;flex-shrink:0}.bulk-edit-footer .btn{flex:1}@keyframes bulk-edit-pop{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.bulk-edit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.bulk-edit-header h3{font-size:1rem;font-weight:600}.bulk-edit-modal .step-edit-preview{margin-bottom:.75rem}.bulk-upload-progress{padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem}.bulk-upload-progress-header{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;margin-bottom:.5rem}.bulk-upload-progress-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.bulk-upload-progress-fill{height:100%;background:var(--brand);border-radius:3px;transition:width .4s ease-out}.bulk-upload-progress-meta{display:block;font-size:.75rem;margin-top:.35rem}.step-form{padding:.75rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.step-form-actions{display:flex;gap:.5rem}.cover-image{width:100%;max-height:260px;object-fit:cover;display:block;border-radius:var(--radius)}.cover-image-actions{display:flex;gap:.4rem;margin-top:.4rem}.shared-hero{width:calc(100% + 4rem);margin:-2rem -2rem 0;height:260px;overflow:hidden;border-radius:var(--radius) var(--radius) 0 0;flex-shrink:0}.shared-hero img{width:100%;height:100%;object-fit:cover;display:block}.shared-hero-placeholder{width:calc(100% + 4rem);margin:-2rem -2rem 0;height:180px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:4rem;background:linear-gradient(135deg,#e8ecff,#d4dbff);border-radius:var(--radius) var(--radius) 0 0}.shared-strand-title{font-size:1.6rem;font-weight:800;letter-spacing:-.5px;line-height:1.2;margin-top:1.25rem}.shared-strand-meta{display:flex;align-items:center;gap:.75rem;margin-top:.4rem;flex-wrap:wrap}.shared-strand-owner{font-size:.85rem;color:var(--muted)}.shared-strand-owner a{color:var(--brand);text-decoration:none;font-weight:600}.shared-strand-owner a:hover{text-decoration:underline}.tag-sharing-hint{font-size:.8rem;padding:.5rem .75rem;border:1px dashed var(--border);border-radius:var(--radius);text-align:center}.tag-picker{margin:1rem 0 .5rem;padding:.75rem 0;border-top:1px solid var(--border)}.tag-picker-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:.5rem}.tag-chip-list{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.tag-chip{display:inline-flex;align-items:center;gap:.25rem;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:.2rem .5rem .2rem .65rem;font-size:.82rem;font-weight:500}.tag-chip-remove{background:none;border:none;cursor:pointer;color:var(--muted);font-size:1rem;line-height:1;padding:0 .1rem;display:flex;align-items:center}.tag-chip-remove:hover:not(:disabled){color:var(--danger, #e53e3e)}.tag-chip-add{background:none;border:1px dashed var(--border);border-radius:999px;padding:.2rem .65rem;font-size:.82rem;color:var(--brand);cursor:pointer}.tag-chip-add:hover{background:var(--surface)}.tag-empty{font-size:.82rem}.tag-picker-list{list-style:none;padding:0;margin:.5rem 0 0;border:1px solid var(--border);border-radius:.5rem;overflow:hidden;max-height:12rem;overflow-y:auto}.tag-picker-option{width:100%;text-align:left;background:none;border:none;padding:.55rem .75rem;font-size:.875rem;cursor:pointer;border-bottom:1px solid var(--border)}.tag-picker-list li:last-child .tag-picker-option{border-bottom:none}.tag-picker-option:hover:not(:disabled){background:var(--surface);color:var(--brand)}.step-images{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.step-image-thumb{position:relative;width:120px;height:120px;border-radius:6px;overflow:hidden;border:1px solid var(--border);flex-shrink:0}.step-image-thumb img,.step-video-thumb{width:100%;height:100%;object-fit:cover;display:block}.step-image-delete{position:absolute;top:2px;right:2px;width:18px;height:18px;border-radius:50%;background:#0000008c;color:#fff;border:none;font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;padding:0}.step-image-thumb:hover .step-image-delete{opacity:1}.step-image-delete:disabled{cursor:not-allowed}.step-image-add{width:120px;height:120px;border:1px dashed var(--border);border-radius:6px;background:transparent;color:var(--muted);font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,color .15s;padding:0;flex-shrink:0}.step-image-add:hover:not(:disabled){border-color:var(--brand);color:var(--brand)}.step-image-add:disabled{opacity:.6;cursor:not-allowed}.step-images-readonly{flex-direction:column;gap:.5rem}.step-image-full{width:100%;border-radius:6px;display:block;border:1px solid var(--border)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:2rem;height:2rem;border:3px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .7s linear infinite}.spinner-wrapper{display:flex;justify-content:center;align-items:center;padding:3rem 1rem}.spinner-sm{width:1rem;height:1rem;border-width:2px}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.45}}.skeleton-block{background:var(--border);border-radius:var(--radius);animation:skeleton-pulse 1.5s ease-in-out infinite}.strand-tile-skeleton{height:185px}.step-skeleton{height:52px;border-radius:6px}.spin-page-header{display:flex;align-items:center;gap:1rem}.back-link{color:var(--muted);font-size:.85rem;text-decoration:none}.back-link:hover{color:var(--text)}.spin-subtitle{text-align:center;margin-top:-.5rem}.spin-all-visited{text-align:center;padding:2rem 0}.continent-tabs{display:flex;flex-wrap:wrap;gap:.4rem}.continent-tab{padding:.35rem .85rem;border-radius:999px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.85rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.continent-tab:hover{background:var(--bg);color:var(--text)}.continent-tab.active{background:var(--brand);color:#fff;border-color:var(--brand)}.wheel-wrapper{display:flex;flex-direction:column;align-items:center;gap:1rem}.wheel-canvas{max-width:100%;height:auto;display:block}.spin-btn{min-width:120px}.celebration-canvas{position:fixed;top:0;right:0;bottom:0;left:0;z-index:350;pointer-events:none;width:100%;height:100%}.spin-result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:center;justify-content:center;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:spin-overlay-in .2s ease-out}@keyframes spin-overlay-in{0%{opacity:0}to{opacity:1}}.spin-result-popup{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem 3rem;background:var(--surface);border-radius:20px;text-align:center;box-shadow:0 20px 60px #00000040,0 0 0 1px #ffffff1a;animation:spin-popup-in .35s cubic-bezier(.34,1.56,.64,1)}@keyframes spin-popup-in{0%{opacity:0;transform:scale(.5) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.spin-result-flag{font-size:4rem;line-height:1}.spin-result-name{font-size:1.6rem;font-weight:800;color:var(--text)}.spin-result-hint{font-size:.85rem;color:var(--muted);margin-bottom:.5rem}.spin-result-close{min-width:100px}.dashboard-actions{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:1rem}.dash-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.35rem;padding:1rem .5rem;border-radius:14px;text-decoration:none;color:#fff;font-weight:700;position:relative;overflow:hidden;transition:transform .15s,box-shadow .15s}.dash-action:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000002e}.dash-action:active{transform:translateY(0)}.dash-action-icon{font-size:1.6rem;line-height:1}.dash-action-label{font-size:.75rem;letter-spacing:.02em;text-align:center;text-shadow:0 1px 2px rgba(0,0,0,.15)}.dash-action--feed{background:linear-gradient(135deg,#4f6ef7,#6c8cff);box-shadow:0 4px 14px #4f6ef759}.dash-action--spin{background:linear-gradient(135deg,#f7794f,#ffaa6c);box-shadow:0 4px 14px #f7794f59}.dash-action--explore{background:linear-gradient(135deg,#22c55e,#4ade80);box-shadow:0 4px 14px #22c55e59}.dash-action--about{background:linear-gradient(135deg,#a855f7,#c084fc);box-shadow:0 4px 14px #a855f759}.unvisited-header{display:flex;align-items:center;gap:1rem}.unvisited-subtitle{text-align:center;margin-top:-.5rem}.unvisited-empty{text-align:center;padding:2rem 0}.unvisited-total{font-size:.95rem;color:var(--muted);text-align:center}.unvisited-total strong{color:var(--brand);font-size:1.1rem}.unvisited-groups{display:flex;flex-direction:column;gap:1rem}.unvisited-group{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.unvisited-group-header{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem;background:var(--bg);border-bottom:1px solid var(--border)}.unvisited-group-name{font-size:.95rem;font-weight:600;color:var(--text)}.unvisited-group-count{font-size:.8rem;font-weight:600;color:var(--surface);background:var(--brand);border-radius:999px;padding:.1rem .55rem;min-width:1.5rem;text-align:center}.unvisited-country-list{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:0}.unvisited-country-item{display:flex;align-items:center;gap:.5rem;padding:.45rem 1rem;font-size:.875rem;border-bottom:1px solid var(--border);border-right:1px solid var(--border)}.unvisited-country-item:last-child{border-bottom:none}.unvisited-country-flag{font-size:1.1rem;line-height:1}@keyframes slide-from-right{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slide-from-left{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}.step-viewer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.25rem;padding:2rem 1.5rem;overflow:hidden}.step-viewer-overlay-toolbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;max-width:600px;flex-shrink:0}.step-viewer-counter{font-size:.95rem;font-weight:600;color:var(--muted)}.step-viewer-card{width:100%;max-width:600px;border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem;background:var(--surface);box-shadow:0 4px 24px #4f6ef714;flex-shrink:1;min-height:0;overflow-y:auto}.step-viewer-card .step-image-full,.step-viewer-card video.step-image-full{width:auto;max-width:100%;max-height:45dvh;object-fit:contain;margin:0 auto}.step-viewer-card.anim-from-right{animation:slide-from-right .25s ease}.step-viewer-card.anim-from-left{animation:slide-from-left .25s ease}.step-viewer-nav{display:flex;gap:.5rem;justify-content:center;width:100%;max-width:600px;flex-shrink:0}.step-nav-btn{font-size:1.5rem;min-width:3.5rem;padding:.6rem 1rem;display:flex;align-items:center;justify-content:center}.img-carousel{display:flex;flex-direction:column;gap:.6rem;margin-top:.5rem}.img-carousel-media{display:flex;justify-content:center}.img-carousel-skeleton{width:100%;height:240px;border-radius:6px}.img-carousel-dots{display:flex;gap:.35rem;align-items:center;justify-content:center}.img-carousel-dot{width:7px;height:7px;border-radius:50%;border:none;background:var(--border);cursor:pointer;padding:0;transition:background .15s,transform .15s}.img-carousel-dot.active{background:var(--muted);transform:scale(1.25)}.step-viewer-dots{display:flex;gap:.4rem;align-items:center;justify-content:center;flex-wrap:wrap;flex:1}.step-viewer-dot{width:10px;height:10px;border-radius:50%;border:none;background:var(--border);cursor:pointer;padding:0;transition:background .15s,transform .15s}.step-viewer-dot.active{background:var(--brand);transform:scale(1.3)}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#000000eb;display:flex;align-items:center;justify-content:center;cursor:zoom-out}.lightbox-close{position:absolute;top:1rem;left:1rem;background:#ffffff26;border:none;color:#fff;font-size:1.2rem;width:2.25rem;height:2.25rem;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;line-height:1}.lightbox-close:hover{background:#ffffff4d}.lightbox-image{max-width:100%;max-height:100dvh;object-fit:contain;cursor:default;border-radius:4px}.step-image-clickable{cursor:zoom-in}@media(max-width:480px){.step-list-header{flex-direction:column;align-items:stretch;gap:.5rem}.step-list-actions{position:fixed;bottom:calc(64px + env(safe-area-inset-bottom,0px));left:0;right:0;z-index:150;flex-direction:row;gap:.5rem;padding:.6rem 1rem;background:var(--bg);border-top:1px solid var(--border);box-shadow:0 -2px 8px #00000014}.step-list-actions .btn{flex:1;padding:.7rem .75rem;font-size:.85rem;justify-content:center}.step-item{flex-direction:column;gap:.5rem}.step-actions{align-self:stretch;justify-content:flex-start;gap:.5rem}.step-actions .btn{flex:1;text-align:center;padding:.45rem .5rem;font-size:.8rem}.step-image-thumb,.step-image-add{width:90px;height:90px}.step-image-delete{opacity:1;width:22px;height:22px;font-size:14px;top:4px;right:4px}.bulk-edit-overlay{align-items:flex-end;padding:0}.bulk-edit-modal{width:100%;max-width:100%;border-radius:var(--radius) var(--radius) 0 0;max-height:80dvh;padding:1rem;animation:bulk-edit-slide-up .25s ease-out}@keyframes bulk-edit-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.bulk-edit-modal .step-edit-preview{border-radius:6px;height:140px}.bulk-edit-modal .step-edit-preview-media{height:140px}.bulk-edit-footer{padding-bottom:calc(env(safe-area-inset-bottom,0px) + .25rem)}.bulk-upload-progress{padding:1rem}.bulk-upload-progress-header{font-size:.9rem}.bulk-upload-progress-track{height:8px}.step-form input,.step-form textarea,.step-form select{font-size:16px;padding:.6rem}.step-form-actions{gap:.5rem}.step-form-actions .btn{flex:1;padding:.6rem;font-size:.85rem}.step-edit-preview,.step-edit-preview-media{height:180px}}@media(hover:none){.step-image-delete{opacity:1}}@media(max-width:480px){.strand-toolbar{flex-direction:column;align-items:stretch;gap:.5rem}.strand-toolbar-actions{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.strand-toolbar-actions .btn{width:100%;padding:.55rem .4rem;font-size:.8rem;text-align:center;justify-content:center;white-space:nowrap}.cover-image-actions{flex-direction:column}.cover-image-actions .btn{width:100%;padding:.55rem;font-size:.85rem;text-align:center}.share-url-row{flex-direction:column;align-items:stretch;gap:.4rem}.share-url-row .btn{width:100%;text-align:center;padding:.55rem}.strand-edit-form input,.strand-edit-form textarea,.strand-edit-form select{font-size:16px;padding:.6rem}.strand-form-actions{flex-direction:column}.strand-form-actions .btn{width:100%;padding:.6rem;font-size:.85rem}}.step-item-clickable{cursor:pointer;transition:background .12s}.step-item-clickable:hover{background:var(--bg)}.unvisited-country-name{color:var(--text)}.app-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 0 .25rem;font-size:.8rem}.app-footer-link{color:var(--brand);text-decoration:none;font-weight:500}.app-footer-link:hover{color:var(--text);text-decoration:underline}.app-footer-sep{color:var(--muted)}.about-page{gap:1.5rem}.privacy-policy-page{gap:1rem}.privacy-effective-date{font-size:.85rem;margin-top:-.5rem}.privacy-section{margin-bottom:.5rem}.privacy-section h3{font-size:1rem;margin-bottom:.35rem}.privacy-section p,.privacy-section li{font-size:.9rem;line-height:1.6}.privacy-section ul{padding-left:1.25rem;margin:.25rem 0}.privacy-section a{color:var(--primary)}.register-consent{text-align:center;margin-top:.5rem;font-size:.8rem}.consent-link{color:var(--primary);text-decoration:underline}.about-tagline{font-size:1.3rem;font-weight:700;text-align:center;color:var(--text)}.about-intro{text-align:center;color:var(--muted);font-size:.95rem;max-width:520px;margin:0 auto}.about-features{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;width:100%}.about-feature{display:flex;gap:.75rem;align-items:flex-start;background:var(--surface-alt, #f7f8fa);border:1px solid var(--border);border-radius:var(--radius);padding:.875rem}.about-feature-icon{font-size:1.5rem;flex-shrink:0}.about-feature p{margin:.2rem 0 0;font-size:.85rem;color:var(--muted)}.about-cta{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding-top:.5rem}.about-cta-buttons{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}.about-leaderboard-btn{padding:.75rem 1.5rem;font-size:1.05rem;font-weight:700;text-decoration:none;background:linear-gradient(135deg,#ffe135,#f6c90e,#e0a800);background-size:200% 200%;color:#1a1a1a;border-radius:var(--radius);border:none;cursor:pointer;box-shadow:0 2px 12px #e6a80073,0 1px 3px #0000001f;animation:gold-shimmer 2.5s ease infinite;transition:filter .15s ease,box-shadow .15s ease}.about-leaderboard-btn:hover{filter:brightness(1.08);box-shadow:0 4px 20px #e6a800a6,0 2px 6px #00000026;text-decoration:none}@keyframes gold-shimmer{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.about-changelog-link{font-size:.85rem;text-decoration:none}.about-changelog-link:hover{text-decoration:underline}.changelog-page{gap:1.25rem}.changelog-heading{text-align:center;font-size:1.3rem}.changelog-sub{text-align:center;font-size:.85rem}.changelog-list{display:flex;flex-direction:column;gap:1.5rem;width:100%}.changelog-entry{border:1px solid var(--border);border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;gap:.75rem;position:relative}.changelog-badge{display:inline-block;background:var(--brand);color:#fff;font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:999px;align-self:flex-start}.changelog-meta{display:flex;flex-direction:column;gap:.15rem}.changelog-date{font-size:.8rem;color:var(--muted)}.changelog-title{font-size:1rem;font-weight:700;margin:0}.changelog-section{display:flex;flex-direction:column;gap:.35rem}.changelog-section ul{margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.2rem;font-size:.875rem}.changelog-section-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.1rem .45rem;border-radius:999px;align-self:flex-start}.changelog-section-label.new{background:#e6f4ea;color:#1a7f37}.changelog-section-label.improved{background:#e8f0fe;color:#1a56db}.changelog-section-label.fixed{background:#fff3e0;color:#b45309}.changelog-footer{display:flex;gap:.75rem;justify-content:center;padding-top:.5rem}.bon-voyage-wrapper{position:relative;display:inline-flex;align-items:center}.bon-voyage-btn{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .55rem;border:1px solid var(--border);border-radius:999px;background:transparent;color:var(--muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,color .15s,border-color .15s;line-height:1}.bon-voyage-btn:hover:not(:disabled){background:var(--bg);color:var(--text);border-color:var(--brand)}.bon-voyage-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}.bon-voyage-btn.active:hover:not(:disabled){background:#fef2f2;color:var(--danger);border-color:#fecaca}.bon-voyage-btn:disabled{opacity:.6;cursor:not-allowed}.bon-voyage-icon{font-size:.9rem;line-height:1}.bon-voyage-count{font-variant-numeric:tabular-nums}.bon-voyage-hint{position:absolute;top:calc(100% + 4px);left:50%;transform:translate(-50%);white-space:nowrap;font-size:.75rem;color:var(--surface);background:var(--text);padding:.25rem .6rem;border-radius:4px;z-index:10}.notif-bell-wrapper{position:fixed;top:1rem;right:1rem;z-index:50}.notif-bell-btn{position:relative;font-size:1.5rem;line-height:1;padding:.45rem .6rem}.notif-bell-badge{position:absolute;top:-4px;right:-6px;background:var(--danger);color:#fff;font-size:.65rem;font-weight:700;min-width:1.25rem;height:1.25rem;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 .3rem;line-height:1;pointer-events:none;box-shadow:0 0 0 2px #fff;animation:notif-badge-pulse 2s ease-in-out infinite}@keyframes notif-badge-pulse{0%,to{box-shadow:0 0 0 2px #fff}50%{box-shadow:0 0 0 2px #fff,0 0 0 5px #e0404059}}.notif-bell-btn--unread{background:#e040401a;border-color:#e0404059}.notif-bell-btn--unread:hover:not(:disabled){background:#e040402e}.notif-dropdown{position:absolute;top:calc(100% + .4rem);right:0;width:320px;max-height:400px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 24px #4f6ef71f;display:flex;flex-direction:column}.notif-dropdown-header{padding:.75rem 1rem;font-weight:700;font-size:.9rem;border-bottom:1px solid var(--border)}.notif-dropdown-loading,.notif-dropdown-error,.notif-dropdown-empty{padding:1.25rem 1rem;text-align:center;font-size:.85rem;color:var(--muted)}.notif-dropdown-error{color:var(--danger)}.notif-item{display:flex;flex-direction:column;gap:.15rem;padding:.65rem 1rem;text-decoration:none;color:var(--text);border-bottom:1px solid var(--border);transition:background .12s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg)}.notif-unread{background:#eff6ff}.notif-item-text{font-size:.85rem;line-height:1.35}.notif-bon-voyage,.notif-leaderboard{color:#b8860b;font-weight:600}.notif-tripstrand{color:#4f6ef7;font-weight:600}.notif-moderation{color:#d32f2f}.notif-item-bottom{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.notif-item-time{font-size:.75rem;color:var(--muted)}.notif-follow-back{font-size:.7rem;font-weight:600;padding:.2rem .55rem;border-radius:var(--radius);border:1px solid var(--brand);background:var(--brand);color:#fff;cursor:pointer;white-space:nowrap;transition:background .12s,opacity .12s}.notif-follow-back:hover:not(:disabled){opacity:.85}.notif-follow-back:disabled{opacity:.6;cursor:default}.notif-follow-back--following{background:transparent;color:var(--muted);border-color:var(--border)}.notif-follow-back--following:hover:not(:disabled){border-color:var(--danger, #e53e3e);color:var(--danger, #e53e3e);background:transparent}@media(max-width:400px){.notif-dropdown{width:calc(100vw - 2rem);max-width:400px}}body.has-bottom-nav{padding-bottom:calc(64px + env(safe-area-inset-bottom,0px))}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--surface);border-top:1px solid var(--border);transition:transform .2s ease-out,opacity .2s ease-out;height:calc(64px + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);z-index:200}.bottom-nav--hidden{transform:translateY(100%);opacity:0;pointer-events:none}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);text-decoration:none;font-size:.65rem;font-weight:500;transition:color .15s}.bottom-nav-item:hover,.bottom-nav-item--active{color:var(--brand)}.bottom-nav-icon{width:22px;height:22px;flex-shrink:0}.notif-bell-wrapper--nav{position:static;flex:1;display:flex;align-items:stretch}.notif-nav-btn{width:100%;background:none;border:none;cursor:pointer;padding:0}.notif-nav-btn:hover,.notif-nav-btn--unread{color:var(--brand)}.notif-nav-icon-wrap{position:relative;display:flex;align-items:center;justify-content:center}.notif-bell-badge--nav{top:-6px;right:-8px}.notif-dropdown--nav{position:fixed;bottom:calc(64px + env(safe-area-inset-bottom,0px) + .4rem);right:.5rem;top:auto;left:auto;max-height:60vh}@media(max-width:480px){.notif-dropdown--nav{right:-.5rem;width:calc(100vw - 2rem);max-width:320px}}@media(max-width:480px){.leaderboard-table{table-layout:fixed}.leaderboard-table th,.leaderboard-table td{padding:.5rem .3rem;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.leaderboard-rank{width:14%}.leaderboard-count{width:18%}.leaderboard-follow{width:30%}.leaderboard-name-cell{min-width:0;overflow:hidden}.leaderboard-follow .btn{font-size:.65rem;padding:.2rem .35rem;max-width:100%}}.co-author-invite-card{text-align:center;padding:1rem 0}.co-author-invite-icon{font-size:3rem;margin-bottom:.5rem}.co-author-invite-title{margin:0 0 .75rem;font-size:1.3rem}.co-author-invite-body{margin-bottom:.5rem}.co-author-invite-desc{margin-bottom:.75rem}.co-author-invite-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.25rem}.co-author-invite-result{text-align:center;padding:1rem 0;display:flex;flex-direction:column;align-items:center;gap:.75rem}.co-author-invite-result-icon{font-size:3rem}.co-author-manager{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.co-author-manager-label{font-size:.8rem;font-weight:600;color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.co-author-list{list-style:none;padding:0;margin:0 0 .75rem;display:flex;flex-direction:column;gap:.4rem}.co-author-item{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.co-author-name{font-size:.9rem}.co-author-empty{font-size:.85rem;margin-bottom:.5rem}.co-author-pending-badge{display:inline-block;margin-left:.4rem;font-size:.65rem;font-weight:600;background:var(--color-surface);color:var(--color-muted);border:1px solid var(--color-border);padding:.1rem .4rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em;vertical-align:middle}.co-author-picker-list{list-style:none;padding:0;margin:.5rem 0 0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);max-height:12rem;overflow-y:auto}.co-author-picker-option{display:block;width:100%;text-align:left;padding:.5rem .75rem;background:none;border:none;cursor:pointer;font-size:.9rem;color:var(--color-text)}.co-author-picker-option:hover{background:var(--color-hover)}.co-author-picker-option:disabled{opacity:.5;cursor:default}.strand-tile-co-authors{display:flex;gap:.2rem;align-items:center}.strand-tile-co-author-avatar{width:1.2rem;height:1.2rem;border-radius:50%;background:var(--color-primary);color:#fff;font-size:.6rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.strand-tile-badge{font-size:.65rem;font-weight:600;background:var(--color-primary-light, #e8edff);color:var(--color-primary);padding:.1rem .4rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}.strand-tile-badge--owner{background:#fef3e2;color:#b37400}.profile-card-co-authors{display:flex;flex-wrap:wrap;gap:.4rem;width:100%}.profile-card-co-author{display:inline-flex;align-items:center;gap:.25rem;text-decoration:none;color:var(--color-text);font-size:.75rem}.profile-card-co-author:hover{text-decoration:underline}.profile-card-co-author-avatar{width:1.2rem;height:1.2rem;border-radius:50%;color:#fff;font-size:.6rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.profile-card-co-author-name{max-width:6rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-section-heading{font-size:1rem;font-weight:600;color:var(--color-muted);text-transform:uppercase;letter-spacing:.05em;margin:1.5rem 0 .75rem}.admin-user-email{font-size:.8rem;margin-left:.4rem}.admin-role-badge{display:inline-block;font-size:.75rem;font-weight:600;padding:.15rem .5rem;border-radius:999px;background:var(--border);color:var(--muted)}.admin-role-badge--admin{background:var(--brand);color:#fff}.admin-delete-confirm{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.admin-delete-confirm-text{font-size:.85rem;font-weight:600;color:var(--danger)}.admin-unpublish-btn{margin-top:.4rem}.admin-feed-badges{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.25rem}.admin-feed-badge{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.admin-feed-badge.badge-success{background:#e6f9ee;color:#1a8a4a}.admin-feed-badge.badge-muted{background:#f0f0f0;color:#888}.shared-header-actions{display:flex;gap:.4rem;align-items:center}.terms-page{text-align:left}.terms-page h2{text-align:center}.terms-effective-date{text-align:center;color:var(--muted);font-size:.85rem;margin-bottom:1.5rem}.terms-content section{margin-bottom:1.5rem}.terms-content h3{font-size:1rem;margin-bottom:.5rem}.terms-content p{margin-bottom:.5rem;line-height:1.6;color:var(--text)}.terms-content ul{margin:.5rem 0 .5rem 1.5rem;line-height:1.6}.terms-content li{margin-bottom:.25rem}.terms-checkbox-label{display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;margin:.75rem 0 .25rem;cursor:pointer}.terms-checkbox-label input[type=checkbox]{margin-top:.2rem;flex-shrink:0}.terms-link{color:var(--brand);text-decoration:underline}.terms-link:hover{color:var(--text)}.accept-terms-page{text-align:center}.accept-terms-intro{color:var(--text);line-height:1.6;margin-bottom:1rem}.accept-terms-links{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.25rem}.accept-terms-page .terms-checkbox-label{justify-content:center;margin-bottom:1rem}.accept-terms-logout{margin-top:.75rem}.report-link{background:none;border:none;padding:0;font-size:.85rem;color:var(--color-muted, #888);text-decoration:underline;cursor:pointer}.report-link:hover:not(:disabled){color:var(--color-danger, #e05c5c)}.report-link:disabled{cursor:default;opacity:.6;text-decoration:none}.report-reason-group{border:1px solid var(--color-border, #e0e0e0);border-radius:8px;padding:.75rem 1rem;margin:.75rem 0}.report-reason-group legend{padding:0 .5rem;font-weight:600}.report-reason-option{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;cursor:pointer}.modal-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem;flex-wrap:wrap}.admin-reports-filter{display:flex;align-items:center;gap:.5rem;margin:.75rem 0}.admin-reports-table{width:100%;border-collapse:collapse;font-size:.9rem}.admin-reports-table th,.admin-reports-table td{text-align:left;padding:.5rem .6rem;border-bottom:1px solid var(--color-border, #e0e0e0)}.admin-reports-table th{font-weight:600;color:var(--color-muted, #888)}.admin-reports-preview{max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-reports-detail{display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1rem;margin:.75rem 0}.admin-reports-detail dt{font-weight:600;color:var(--color-muted, #888)}.admin-reports-detail dd{margin:0}.admin-reports-link{display:inline-block;padding:.35rem .1rem;color:var(--color-link, #2563eb);text-decoration:underline;min-height:32px}.admin-reports-review-links{display:flex;flex-wrap:wrap;gap:.6rem;margin:.75rem 0 1rem}.admin-reports-review-link{flex:1 1 auto;min-height:48px;padding:.85rem 1.1rem;font-size:1rem;text-align:center;display:inline-flex;align-items:center;justify-content:center}.admin-reports-review-link-placeholder{flex:1 1 auto;min-height:48px;display:inline-flex;align-items:center;justify-content:center;font-style:italic}@media(max-width:640px){.admin-reports-table{font-size:.95rem}.admin-reports-table th,.admin-reports-table td{padding:.65rem .5rem}.admin-reports-link{padding:.6rem .1rem;min-height:44px}.admin-reports-review-links{flex-direction:column}.admin-reports-review-link{width:100%;min-height:52px;font-size:1.05rem}.modal-actions .btn{min-height:48px;padding:.8rem 1rem;flex:1 1 45%}}.banner.success{background:#e6f7ec;color:#1d6f3a;border:1px solid #a8dcb8;padding:.75rem 1rem;border-radius:8px;margin:.75rem 0}.blocked-users-list{list-style:none;padding:0;margin:1rem 0}.blocked-users-row{display:flex;justify-content:space-between;align-items:center;padding:.625rem 0;border-bottom:1px solid var(--color-border, #e0e0e0)}.blocked-users-row:last-child{border-bottom:none}.blocked-users-name{font-weight:500}.blocked-users-meta{color:var(--color-muted, #888);font-size:.85rem}.review-creds{margin:2rem 0;padding-top:1.5rem;border-top:1px solid var(--color-border, #e0e0e0)}.review-creds h3{margin-bottom:.75rem}.review-creds h4{margin:1rem 0 .5rem;font-size:.95rem;color:var(--color-muted, #888)}.review-creds-limit{font-size:.85rem;margin-top:.25rem}.review-creds-new{margin:1rem 0;padding:1rem;border:2px solid var(--color-warning, #e09a1a);border-radius:8px;background:var(--color-warning-bg, #fef9e7)}.review-creds-warning{font-weight:600;color:var(--color-warning, #e09a1a);margin-bottom:.75rem}.review-creds-field{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.review-creds-field label{font-weight:500;min-width:5rem}.review-creds-field code{flex:1;font-size:.9rem;word-break:break-all}.review-creds-list{list-style:none;padding:0;margin:0}.review-creds-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem 0;border-bottom:1px solid var(--color-border, #e0e0e0)}.review-creds-item:last-child{border-bottom:none}.review-creds-info{display:flex;flex-direction:column;gap:.2rem}.review-creds-info code{font-size:.85rem}.review-creds-expired{opacity:.5}.review-creds-confirm{display:flex;align-items:center;gap:.5rem}
