*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary:#0a0a14;--bg-secondary:#11111d;--bg-card:#1a1a2e;--bg-surface:#15152a;--text-primary:#e8e8f4;--text-secondary:#9090a8;--text-dim:#5a5a72;--border-color:#24243a;--accent:#4361ee;--radius:8px;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}html{font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}#root{min-height:100dvh}input,textarea,button,select{font:inherit;color:inherit}a{color:inherit}.app{max-width:1200px;margin:0 auto;padding:28px 20px 56px}.app-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.app-brand-link{color:inherit;align-items:center;gap:10px;text-decoration:none;transition:opacity .12s;display:inline-flex}.app-brand-link:hover{opacity:.85}.app-brand-logo{filter:drop-shadow(0 2px 8px #6366f12e);border-radius:8px;width:32px;height:32px;display:block}.app-brand-name{letter-spacing:-.01em;color:var(--text-primary);font-size:1.15rem;font-weight:700;line-height:1.2}.user-chip{color:var(--text-secondary);align-items:center;gap:8px;font-size:.85rem;display:flex}.user-chip img{object-fit:cover;border-radius:50%;width:24px;height:24px}.home-panel{flex-direction:column;gap:22px;display:flex}.section-title{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:12px;font-size:.78rem;font-weight:600}.home-hero{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:32px 32px 36px;position:relative;overflow:hidden}.hero-decorated{background:radial-gradient(circle at 12% -10%, #6366f12e, transparent 45%), radial-gradient(circle at 110% 0%, #06d6a024, transparent 50%), var(--bg-secondary)}.hero-preview{flex-wrap:wrap;gap:6px;margin-bottom:22px;display:flex}.hero-preview-cell{border:1px solid var(--cat-color,var(--border-color));background:linear-gradient(145deg, color-mix(in srgb, var(--cat-color,#888) 22%, transparent), color-mix(in srgb, var(--cat-color,#888) 8%, transparent));width:52px;height:52px;color:var(--cat-color,var(--text-secondary));border-radius:8px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;animation:.5s both heroPop;display:flex;position:relative}@keyframes heroPop{0%{opacity:0;transform:translateY(8px)scale(.92)}to{opacity:1;transform:translateY(0)scale(1)}}.hero-preview-num{color:var(--text-dim);font-size:.55rem;line-height:1;position:absolute;top:4px;left:5px}.hero-preview-sym{letter-spacing:-.02em;font-size:.95rem;font-weight:700}.home-eyebrow{letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);margin-bottom:8px;font-size:.72rem}.home-title{letter-spacing:-.02em;color:var(--text-primary);margin-bottom:14px;font-size:2rem;font-weight:700;line-height:1.15}.home-title .grad{background:linear-gradient(135deg,#4361ee 0%,#f72585 50%,#06d6a0 100%);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text}.home-subtitle{color:var(--text-secondary);max-width:62ch;font-size:.98rem;line-height:1.55}.home-actions{flex-wrap:wrap;gap:10px;margin-top:22px;display:flex}.home-cta{border-radius:8px;align-items:center;padding:11px 20px;font-size:.92rem;text-decoration:none;display:inline-flex;box-shadow:0 6px 20px -8px #4361ee8c}.share-link-btn{margin-left:auto;padding:6px 12px;font-size:.82rem}.stats-row{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:18px 20px;transition:border-color .15s,transform .15s;position:relative;overflow:hidden}.stat-card:before{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff08,#0000 60%);position:absolute;inset:0}.stat-card:hover{border-color:var(--text-dim);transform:translateY(-1px)}.stat-value{letter-spacing:-.02em;color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1.85rem;font-weight:700;line-height:1}.stat-label{color:var(--text-secondary);margin-top:6px;font-size:.85rem;font-weight:500}.stat-hint{color:var(--text-dim);margin-top:2px;font-size:.72rem}.categories-grid{grid-template-columns:repeat(2,1fr);gap:12px;display:grid}.category-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:18px 20px;transition:border-color .15s,transform .15s;position:relative;overflow:hidden}.category-card:after{content:"";background:var(--cat-color);opacity:.85;height:3px;position:absolute;top:0;left:0;right:0}.category-card:hover{border-color:var(--cat-color);transform:translateY(-1px)}.category-card-head{align-items:center;gap:8px;margin-bottom:4px;display:flex}.category-dot{background:var(--cat-color);border-radius:50%;width:8px;height:8px}.category-card h4{color:var(--text-primary);font-size:1rem;font-weight:600}.category-desc{color:var(--text-dim);margin-bottom:12px;font-size:.82rem}.category-tags{flex-wrap:wrap;gap:6px;display:flex}.category-tag{border:1px solid;border-radius:999px;padding:3px 9px;font-size:.75rem;font-weight:500;display:inline-block}.home-tips{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:22px 24px}.home-tips ul{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.home-tips li{color:var(--text-secondary);padding-left:14px;font-size:.88rem;line-height:1.5;position:relative}.home-tips li:before{content:"";background:var(--text-dim);border-radius:50%;width:5px;height:5px;position:absolute;top:8px;left:0}.home-tips strong{color:var(--text-primary);font-weight:600}@media (width<=768px){.home-hero{padding:22px 18px 26px}.home-title{font-size:1.55rem}.stats-row{grid-template-columns:repeat(2,1fr)}.categories-grid{grid-template-columns:1fr}.hero-preview-cell{width:44px;height:44px}.hero-preview-sym{font-size:.82rem}}.profile-strip{flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:16px;display:flex}.back-link{margin:0;font-size:.85rem}.profile-strip-info{align-items:center;gap:10px;display:flex}.profile-strip-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.profile-strip-name{color:var(--text-primary);align-items:center;gap:8px;font-size:.9rem;display:flex}.badge-readonly{background:var(--bg-surface);border:1px solid var(--border-color);color:var(--text-dim);border-radius:999px;padding:1px 8px;font-size:.7rem;font-weight:500;display:inline-block}.app-tabs{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.tabs{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;gap:2px;padding:2px;display:inline-flex}.tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.85rem;transition:color .12s,background .12s;display:inline-flex}.tab:hover:not(:disabled){color:var(--text-primary)}.tab.is-active{background:var(--bg-card);color:var(--text-primary)}.tab:disabled{cursor:default;opacity:.55}.tab-count{color:var(--text-dim);font-variant-numeric:tabular-nums;font-size:.72rem}.tab.is-active .tab-count{color:var(--text-secondary)}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:7px;padding:7px 14px;font-size:.85rem;font-weight:500;transition:opacity .12s,transform 80ms}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:scale(.98)}.btn-secondary{border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:7px;padding:6px 12px;font-size:.85rem;transition:color .12s,border-color .12s}.btn-secondary:hover:not(:disabled){color:var(--text-primary);border-color:var(--text-dim)}.btn-secondary.danger:hover{color:#ef233c;border-color:#ef233c44}.btn-primary:disabled,.btn-secondary:disabled{cursor:default;opacity:.5}.btn-link{color:var(--text-dim);cursor:pointer;background:0 0;border:none;margin-left:4px;padding:0;font-size:.85rem;transition:color .12s}.btn-link:hover{color:var(--text-primary)}.signin-card{background:var(--bg-surface);border:1px solid var(--border-color);text-align:center;border-radius:10px;width:100%;max-width:380px;padding:20px 22px}.signin-title{color:var(--text-primary);margin-bottom:4px;font-size:1.05rem;font-weight:600}.signin-subtitle{color:var(--text-secondary);margin-bottom:16px;font-size:.85rem}.signin-slot{justify-content:center;min-height:44px;display:flex}.auth-required{justify-content:center;padding:32px 0;display:flex}.home-signin{justify-content:flex-start;margin-top:22px;display:flex}.login-error{color:var(--text-secondary);text-align:left;background:#ef233c10;border:1px solid #ef233c44;border-radius:8px;margin-top:12px;padding:10px 12px;font-size:.82rem}.login-error code{background:var(--bg-surface);border-radius:4px;padding:1px 5px;font-size:.78rem}.login-hint{color:var(--text-dim);margin-top:8px;font-size:.78rem}.form-error{color:#ef233c;margin-top:8px;font-size:.85rem}.empty-grid{text-align:center;color:var(--text-dim);padding:28px 16px;font-size:.9rem}.empty-grid .btn-secondary{margin-top:10px}.empty-state{text-align:center;max-width:360px;color:var(--text-secondary);margin:8px auto;padding:28px 20px;font-size:.95rem}.empty-state p{margin-bottom:16px}.content-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:16px}.legend{border-bottom:1px solid var(--border-color);flex-wrap:wrap;justify-content:center;gap:6px 12px;margin-bottom:14px;padding-bottom:12px;display:flex}.legend-item{align-items:center;gap:6px;display:flex}.legend-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.legend-label{color:var(--text-secondary);white-space:nowrap;font-size:.78rem}.periodic-table-wrapper{-webkit-overflow-scrolling:touch;padding:4px 0;position:relative;overflow-x:auto}.periodic-table{gap:4px;min-width:500px;max-width:1100px;margin:0 auto;display:grid}.periodic-table-groups{flex-direction:column;gap:12px;min-width:500px;max-width:1100px;margin:0 auto;display:flex}.periodic-table-groups .periodic-table{grid-template-columns:repeat(var(--grid-cols,18), minmax(48px, 1fr));min-width:0;max-width:none;margin:0}.periodic-table-divider{background:linear-gradient(to right, transparent, var(--border-color) 12%, var(--border-color) 88%, transparent);height:1px;margin:2px 0}.periodic-table.compact{flex-direction:column;align-items:center;gap:6px;width:100%;min-width:0;max-width:664px;display:flex}.periodic-table.compact .periodic-table-divider{align-self:center;width:80%;margin:4px 0}.compact-table-row{grid-template-columns:repeat(var(--row-cols,12), minmax(88px, 104px));justify-content:center;gap:6px;width:100%;display:grid}.element-cell{aspect-ratio:1;border:1px solid var(--border-color);cursor:pointer;background:0 0;border-radius:6px;outline:none;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-width:0;padding:6px 4px;transition:border-color .12s,background .12s;display:flex;position:relative}.element-cell.active{border-color:var(--cat-color-dim);background:var(--cat-color-bg)}.element-cell:hover,.element-cell:focus-visible{border-color:var(--cat-color);background:var(--cat-color-bg);z-index:2}.element-number{color:var(--text-dim);font-size:.65rem;line-height:1;position:absolute;top:4px;left:6px}.element-symbol{color:var(--text-secondary);letter-spacing:-.02em;text-align:center;max-width:100%;font-size:1.25rem;font-weight:600;line-height:1.1;transition:color .12s}.element-cell.active .element-symbol,.element-cell:hover .element-symbol{color:var(--cat-color)}.element-name{color:var(--text-dim);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.66rem;line-height:1.2;overflow:hidden}.element-cell.active .element-name{color:var(--text-secondary)}.element-record{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;max-width:100%;margin-top:1px;font-size:.62rem;font-weight:500;overflow:hidden}.element-status{color:var(--cat-color);margin-top:1px;font-size:.56rem;font-weight:600;line-height:1.3}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;width:100%;max-width:520px;max-height:82vh;padding:22px;animation:.18s slideUp;overflow-y:auto}.modal-header{align-items:flex-start;gap:14px;margin-bottom:20px;display:flex}.modal-element-card{border:1.5px solid;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.modal-element-symbol{color:var(--cat-color);font-size:1.3rem;font-weight:700}.modal-element-info{flex:1;min-width:0}.modal-element-info h2{margin-bottom:4px;font-size:1.1rem;font-weight:600}.modal-badge{border-radius:4px;padding:1px 7px;font-size:.72rem;font-weight:500;display:inline-block}.modal-record-type{color:var(--text-dim);margin-top:4px;font-size:.78rem}.modal-description{color:var(--text-secondary);margin-top:6px;font-size:.78rem;line-height:1.4}.modal-close{color:var(--text-dim);cursor:pointer;background:0 0;border:none;flex-shrink:0;padding:0 4px;font-size:1.4rem;line-height:1;transition:color .12s}.modal-close:hover{color:var(--text-primary)}.modal-form{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:8px;margin-bottom:20px;padding:16px}.modal-form h3{color:var(--text-secondary);margin-bottom:12px;font-size:.85rem;font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.form-grid label{flex-direction:column;gap:4px;display:flex}.form-grid label span{color:var(--text-dim);font-size:.72rem}.form-grid .full-width{grid-column:1/-1}.form-grid input,.form-grid textarea{background:var(--bg-primary);border:1px solid var(--border-color);color:var(--text-primary);border-radius:6px;padding:7px 9px;font-size:.85rem;transition:border-color .12s}.form-grid input:focus,.form-grid textarea:focus{border-color:var(--cat-color);outline:none}.form-grid textarea{resize:vertical}.btn-add{color:#fff;cursor:pointer;border:none;border-radius:6px;width:100%;margin-top:12px;padding:8px;font-size:.88rem;font-weight:500;transition:opacity .12s,transform 80ms}.btn-add:hover{opacity:.88}.btn-add:active{transform:scale(.98)}.modal-history-header{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.modal-history h3{color:var(--text-secondary);font-size:.85rem;font-weight:600}.pb-badge{color:#fff;background:var(--cat-color);vertical-align:middle;border-radius:4px;margin-left:6px;padding:1px 6px;font-size:.58rem;font-weight:700;display:inline-block}.history-list{flex-direction:column;gap:6px;display:flex}.history-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:6px;padding:10px 32px 10px 12px;position:relative}.history-card-main{align-items:baseline;gap:12px;display:flex}.history-date{color:var(--text-dim);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.78rem}.history-value{font-size:.95rem;font-weight:600}.history-media{color:var(--cat-color);border-bottom:1px solid;margin-top:4px;font-size:.74rem;text-decoration:none;display:inline-block}.history-media:hover{opacity:.8}.history-notes{color:var(--text-secondary);margin-top:4px;font-size:.78rem;line-height:1.4}.history-delete{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:1rem;line-height:1;transition:color .12s,background .12s;position:absolute;top:6px;right:6px}.history-delete:hover{color:#ef233c;background:#ef233c1a}@media (width<=768px){.app{padding:18px 12px 40px}.app-header{flex-wrap:wrap;gap:10px;margin-bottom:14px}.app-tabs{flex-wrap:wrap;gap:10px}.tabs{flex:1}.tab{flex:1;justify-content:center}.content-panel{padding:12px}.periodic-table-groups{min-width:0;max-width:none}.periodic-table-groups .periodic-table{grid-template-columns:repeat(var(--grid-cols,18), minmax(64px, 1fr));gap:4px}.periodic-table-groups .element-cell{aspect-ratio:1;min-height:64px;padding:6px 3px}.periodic-table-groups .element-symbol{font-size:.95rem}.periodic-table-groups .element-name{font-size:.58rem}.periodic-table-groups .element-number{font-size:.55rem;top:3px;left:4px}.periodic-table-groups .element-record,.periodic-table-groups .element-status{font-size:.55rem}.periodic-table.compact{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));align-items:stretch;gap:8px;max-width:none;display:grid}.periodic-table.compact .compact-table-row{display:contents}.periodic-table.compact .periodic-table-divider{grid-column:1/-1;width:100%;margin:4px 0 2px}.periodic-table.compact .element-cell{aspect-ratio:auto;text-align:left;border-left:3px solid var(--cat-color);border-radius:8px;grid-template-rows:auto auto;grid-template-columns:44px 1fr;align-items:center;gap:2px 12px;min-height:64px;padding:10px 12px 10px 10px;display:grid}.periodic-table.compact .element-cell .element-symbol{background:var(--cat-color-bg);width:44px;height:44px;color:var(--cat-color);border-radius:8px;grid-area:1/1/3;justify-content:center;place-self:center;align-items:center;font-size:1.05rem;font-weight:700;line-height:1;display:flex}.periodic-table.compact .element-cell .element-name{color:var(--text-primary);text-align:left;white-space:nowrap;text-overflow:ellipsis;grid-area:1/2;font-size:.85rem;font-weight:500;line-height:1.25;overflow:hidden}.periodic-table.compact .element-cell .element-record,.periodic-table.compact .element-cell .element-status{text-align:left;grid-area:2/2;margin:0;font-size:.75rem;line-height:1.2}.periodic-table.compact .element-cell .element-record{color:var(--text-secondary);font-weight:600}.periodic-table.compact .element-cell .element-number{color:var(--text-dim);font-size:.6rem;top:6px;left:auto;right:8px}.modal-overlay{align-items:flex-end;padding:12px}.modal-content{border-radius:12px 12px 0 0;max-height:90vh;padding:18px 16px}.form-grid{grid-template-columns:1fr}}
